home *** CD-ROM | disk | FTP | other *** search
/ Revista CD Expert 8 / Revista CD Expert nº 08 CD1.iso / Utilitarios / Programacao / MS-DOS Interrupt List / inter60d / INTERRUP.P < prev    next >
Text File  |  1999-01-03  |  353KB  |  9,201 lines

  1. Interrupt List, part 16 of 18
  2. Copyright (c) 1989,1990,1991,1992,1993,1994,1995,1996,1997,1998,1999 Ralf Brown
  3. --------*-62---------------------------------
  4. INT 62 - reserved for user interrupt
  5. --------d-62---------------------------------
  6. INT 62 - Adaptec and OMTI controllers - DRIVE 0 DATA
  7. Notes:    this vector stores the third four bytes of the parameter table for
  8.       hard disk 0
  9. SeeAlso: INT 60"Adaptec",INT 61"Adaptec",INT 63"Adaptec"
  10. --------b-62---------------------------------
  11. INT 62 - TI Professional PC - OPTION ROM DATA AREA POINTER (NOT A VECTOR!)
  12. Desc:    the low word of this vector contains the segment of the RAM data area
  13.       to be used by the expansion ROM at F400h:2000h, and the high word
  14.       contains the length of the data area; this segment and size are
  15.       both set to 0000h if no ROM is installed at F400h:2000h
  16. SeeAlso: INT 61"TI Professional PC",INT 63"TI Professional"
  17. SeeAlso: INT 66"TI Professional PC"
  18. --------b-62---------------------------------
  19. INT 62 - HP 95LX - USED BY CALCULATOR
  20. SeeAlso: INT 60/DI=0104h"HP 95LX"
  21. ----------62---------------------------------
  22. INT 62 - MS SQL Server/Sybase DBLIBRARY interface - ???
  23.     AH = function (00h to 07h)
  24.     CX = FFFEh
  25.     DX = FFFFh
  26.     ???
  27. Return: ???
  28. InstallCheck:    test for the string "DBLIBRARY" two bytes past the interrupt
  29.       handler
  30. SeeAlso: AH=08h"SQL"
  31. Index:    installation check;MS SQL Server|installation check;Sybase DBLIBRARY
  32. ----------62---------------------------------
  33. INT 62 - MPAUSE - ???
  34.     details not yet avialable
  35. Program: MPAUSE is a program by Manfred Michael which appeared in the German
  36.      _EGA-Handbuch_ from  m&t-Verlag
  37. --------N-62---------------------------------
  38. INT 62 - XFS v1.76 - FILTERED PACKET DRIVER API
  39. Program: XFS is a shareware Network File System client by Robert Juhasz
  40. Desc:    XFS requires a packet driver to operate.  Since it does redirections,
  41.       etc., it provides its own packet driver entry point, changing the
  42.       signature string of the original packet driver to "XKT DRVR" so that
  43.       it will no longer be found by the packet driver installation check
  44. InstallCheck:    scan for the signature string "PKT DRVR" three bytes past the
  45.       interrupt handler (the same as that for the packet driver
  46.       specification)
  47. Range:    INT 61 to INT 66, selected by scanning for two consecutive free
  48.       vectors and hooking the second
  49. SeeAlso: INT 60"Packet Driver Specification",INT 61"XFS"
  50. ----------62---------------------------------
  51. INT 62 - PC-DRAFT - PRIMARY DISPLAY DRIVER
  52.     ???
  53. Return: ???
  54. Program: PC-DRAFT is a powerful CAD environment by rhv.
  55. SeeAlso: INT 64"PC-DRAFT",INT 65"PC-DRAFT",INT 66"PC-DRAFT",INT 67"PC-DRAFT"
  56. --------N-6200-------------------------------
  57. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - GET PHYSICAL HARDWARE ADDRESS
  58.     AH = 00h
  59.     DS:DX -> 6-byte buffer for address
  60. Return: AX = length of hardware address???
  61. Range:    INT 4C to INT FB, selected by configuration
  62. Note:    the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  63.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  64.       consecutive interrupt (64h by default) if it is loaded
  65. SeeAlso: AH=01h"ETHDEV",AH=04h"ETHDEV",AH=09h"ETHDEV",AH=0Eh"ETHDEV"
  66. SeeAlso: AH=14h"ETHDEV",AH=18h"ETHDEV",AH=FEh,INT 21/AH=3Fh"BW-TCP"
  67. SeeAlso: INT 63/AH=03h"BW-TCP",INT 63/AH=24h"BW-TCP",INT 64/AH=01h"BW-NFS"
  68. --------V-620000-----------------------------
  69. INT 62 u - FGDRIVER v3.03+ - "FG_ALLOCATE" - CREATE VIRTUAL VIDEO PAGE
  70.     AX = 0000h
  71.     BX = page number (0000h-003Fh)
  72. Return: AX = status (0000h,0001h,0007h,0008h) (see #03473)
  73. Program: FGDRIVER is the external video driver for the shareware
  74.       Fastgraph/Light by Ted Gruber Software
  75. InstallCheck:    test for the signature "FG" ten bytes beyond the start of the
  76.       interrupt handler
  77. Notes:    the FGDRIVER functions are rearranged with each major release, but
  78.       their parameters do not change (see #03474)
  79.     The amount of memory required by the virtual video page depends on the
  80.       current video mode
  81. SeeAlso: AX=0001h,AX=0002h,AX=0003h,AX=0038h
  82. Index:    installation check;Fastgraph/Light
  83.  
  84. (Table 03473)
  85. Values for FGDRIVER status:
  86.  0000h    successful
  87.  0001h    specified page is a physical or logical page
  88.  0007h    virtual page created/released, but memory control blocks corrupted
  89.  0008h    not enough memory
  90.  0009h    attempt to free a page which was never created
  91.  FFFCh    insufficient memory
  92.  FFFDh    page already created, or exists as physical or virtual page
  93.  FFFEh    invalid page number
  94.  FFFFh    memory manager not initialized
  95. SeeAlso: #03474
  96.  
  97. (Table 03474)
  98. Values for FGDRIVER functions (by driver version):
  99. Name        v1.10    v3.03    v4.02
  100.  FG_ALLOCATE    0042h    0000h    0000h
  101.  FG_ALLOCCMS    009Dh    0001h    0001h
  102.  FG_ALLOCEMS    009Eh    0002h    0002h
  103.  FG_ALLOCXMS    009Fh    0003h    0003h
  104.  FG_AUTOMODE    0004h    0004h    0004h
  105.  FG_BESTMODE    0003h    0005h    0005h
  106.  FG_BOX        00A2h    0006h    0006h
  107.  FG_BOXDEPTH    00A3h    0007h    0007h
  108.  FG_BOXX     --    0008h    0008h
  109.  FG_BUTTON    0078h    0009h    0009h
  110.  FG_CAPSLOCK    0070h    000Ah    000Ah
  111.  FG_CHGATTR    0035h    000Bh    000Bh
  112.  FG_CHGTEXT    0036h    000Ch    000Ch
  113.  FG_CIRCLE    0030h    000Dh    000Dh
  114.  FG_CIRCLEF     --    000Eh    000Eh
  115.  FG_CLIPMAP     --     --    000Fh
  116.  FG_CLIPMASK    0052h    000Fh    0010h
  117.  FG_CLPIMAGE    004Ah    0010h    0011h
  118.  FG_CLPRECT    002Bh    0011h    0012h
  119.  FG_COLORS     --     --    0013h
  120.  FG_COPYPAGE    005Fh    0012h    0014h
  121.  FG_CURSOR    0007h    0013h    0015h
  122.  FG_DASH    0027h    0014h    0016h
  123.  FG_DASHREL    0028h    0015h    0017h
  124.  FG_DEFCOLOR    0014h    0016h    0018h
  125.  FG_DEFPAGES     --    0017h    0019h
  126.  FG_DISPFILE    004Fh    0018h    001Ah
  127.  FG_DISPLAY    004Dh    0019h    001Bh
  128.  FG_DISPLAYP    004Eh    001Ah    001Ch
  129.  FG_DISPPCX    0060h     --     --
  130.  FG_DRAW    0025h    001Bh    001Dh
  131.  FG_DRAWMAP    0047h    001Ch    001Eh
  132.  FG_DRAWMASK    0051h    001Dh    001Fh
  133.  FG_DRAWREL    0026h    001Eh    0020h
  134.  FG_DRAWRELX     --    001Fh    0021h
  135.  FG_DRAWX     --    0020h    0022h
  136.  FG_DRECT    002Ch    0021h    0023h
  137.  FG_DRWIMAGE    0049h    0022h    0024h
  138.  FG_EGACHECK    0005h    0023h    0025h
  139.  FG_ELLIPSE    002Dh    0024h    0026h
  140.  FG_ELLIPSEF     --    0025h    0027h
  141.  FG_ERASE    001Eh    0026h    0028h
  142.  FG_FADEIN    0064h    0027h    0029h
  143.  FG_FADEOUT    0065h    0028h    002Ah
  144.  FG_FILLPAGE     --    0029h    002Bh
  145.  FG_FINDPAGE     --     --    002Ch
  146.  FG_FLICDONE     --     --    002Dh
  147.  FG_FLICHEAD     --     --    002Eh
  148.  FG_FLICMODE     --     --    002Fh
  149.  FG_FLICOPEN     --     --    0030h
  150.  FG_FLICPLAY     --     --    0031h
  151.  FG_FLICSIZE     --     --    0032h
  152.  FG_FLICSKIP     --     --    0033h
  153.  FG_FLIPMASK    0054h    002Ah    0034h
  154.  FG_FLOOD     --    002Bh    0035h
  155.  FG_FLPIMAGE    004Ch    002Ch    0036h
  156.  FG_FONTSIZE     --    002Dh    0037h
  157.  FG_FREEPAGE    0043h    002Eh    0038h
  158.  FG_GETADDR    0044h    002Fh    0039h
  159.  FG_GETATTR    0037h    0030h    003Ah
  160.  FG_GETBANKS     --     --    003Bh
  161.  FG_GETBLOCK     --    0031h    003Ch
  162.  FG_GETCHAR    0038h    0032h    003Dh
  163.  FG_GETCLIP     --     --    003Eh
  164.  FG_GETCLOCK    0099h    0033h    003Fh
  165.  FG_GETCOLOR    0015h    0034h    0040h
  166.  FG_GETDACS    00A4h    0035h    0041h
  167.  FG_GETENTRY     --    0036h    0042h
  168.  FG_GETHPAGE    0040h    0037h    0043h
  169.  FG_GETIMAGE    0048h    0038h    0044h
  170.  FG_GETINDEX    0016h    0039h    0045h
  171.  FG_GETKEY    006Eh    003Ah    0046h
  172.  FG_GETLINES    0010h    003Bh    0047h
  173.  FG_GETMAP    0046h    003Ch    0048h
  174.  FG_GETMAXX    000Ah    003Dh    0049h
  175.  FG_GETMAXY    000Bh    003Eh    004Ah
  176.  FG_GETMODE    0000h    003Fh    004Bh
  177.  FG_GETPAGE    003Ch    0040h    004Ch
  178.  FG_GETPIXEL    0020h    0041h    004Dh
  179.  FG_GETRGB    001Ch    0042h    004Eh
  180.  FG_GETVIEW     --     --    004Fh
  181.  FG_GETVPAGE    003Eh    0043h    0050h
  182.  FG_GETXBOX     --     --    0051h
  183.  FG_GETXJOY    0076h    0044h    0052h
  184.  FG_GETXJUST     --     --    0053h
  185.  FG_GETXPOS    0021h    0045h    0054h
  186.  FG_GETYBOX     --     --    0055h
  187.  FG_GETYJOY    0077h    0046h    0056h
  188.  FG_GETYJUST     --     --    0057h
  189.  FG_GETYPOS    0022h    0047h    0058h
  190.  FG_HUSH    008Eh    0048h    0059h
  191.  FG_HUSHNEXT    008Fh    0049h    005Ah
  192.  FG_IMAGEBUF     --    004Ah    005Bh
  193.  FG_IMAGESIZ    0062h    004Bh    005Ch
  194.  FG_INITEMS    00A0h    004Ch    005Dh
  195.  FG_INITJOY    0075h    004Dh    005Eh
  196.  FG_INITPM     --     --    005Fh??? (NOP in v4.02)
  197.  FG_INITXMS    00A1h    004Eh    0060h
  198.  FG_INSIDE     --    004Fh    0061h
  199.  FG_INTJOY    0079h    0050h    0062h
  200.  FG_INTKEY    006Fh    0051h    0063h
  201.  FG_INVERT     --     --    0064h
  202.  FG_JUSTIFY     --    0052h    0065h
  203.  FG_KBINIT     --    0053h    0066h
  204.  FG_KBLAST     --     --    0067h
  205.  FG_KBRESET     --     --    0068h
  206.  FG_KBTEST     --    0054h    0069h
  207.  FG_LOADPCX     --     --    006Ah
  208.  FG_LOCATE    0033h    0055h    006Bh
  209.  FG_MAKEPCX    0061h    0057h    006Ch
  210.  FG_MAKEPPR     --    0058h    006Dh
  211.  FG_MAKESPR     --    0059h    006Eh
  212.  FG_MAPRGB    001Dh    005Ah    006Fh
  213.  FG_MEASURE    0098h    005Bh    0070h
  214.  FG_MEMAVAIL    009Bh    005Ch    0071h
  215.  FG_MEMORY     --    005Dh    0072h
  216.  FG_MOUSE256     --     --    0073h
  217.  FG_MOUSEBUT    007Ch    005Eh    0074h
  218.  FG_MOUSECUR    007Eh    005Fh    0075h
  219.  FG_MOUSEFIN     --    0060h    0076h
  220.  FG_MOUSEINI    007Ah    0061h    0077h
  221.  FG_MOUSELIM    0080h    0062h    0078h
  222.  FG_MOUSEMOV    0081h    0063h    0079h
  223.  FG_MOUSEPOS    007Dh    0064h    007Ah
  224.  FG_MOUSEPTR    007Fh    0065h    007Bh
  225.  FG_MOUSESPD    0082h    0066h    007Ch
  226.  FG_MOUSEVIS    007Bh    0067h    007Dh
  227.  FG_MOVE    0023h    0068h    007Eh
  228.  FG_MOVEREL    0024h    0069h    007Fh
  229.  FG_MUSIC    008Ch    006Ah    0080h
  230.  FG_MUSICB    008Dh    006Bh    0081h
  231.  FG_NUMLOCK    0072h    006Ch    0082h
  232.  FG_PACK     --     --    0083h
  233.  FG_PAGESIZE     --    006Dh    0084h
  234.  FG_PAINT    002Fh    006Eh    0085h
  235.  FG_PALETTE    0017h    006Fh    0086h
  236.  FG_PALETTES    0018h    0070h    0087h
  237.  FG_PAN        0066h    0071h    0088h
  238.  FG_PATTERN    0050h    0072h    0089h
  239.  FG_PCXHEAD     --    0073h    008Ah
  240.  FG_PCXMODE     --    0074h    008Bh
  241.  FG_PCXPAL     --     --    008Ch
  242.  FG_PCXRANGE     --     --    008Dh
  243.  FG_PLAYING    0091h    0075h    008Eh
  244.  FG_POINT    001Fh    0076h    008Fh
  245.  FG_POINTX     --    0077h    0090h
  246.  FG_POLYEDGE     --     --    0091h
  247.  FG_POLYFILL     --    0078h    0092h
  248.  FG_POLYGON    002Eh    0079h    0093h
  249.  FG_POLYLINE     --    007Ah    0094h
  250.  FG_POLYOFF     --    007Bh    0095h
  251.  FG_PRINT     --    007Ch    0096h
  252.  FG_PRINTC     --     --    0097h
  253.  FG_PUTBLOCK     --    007Dh    0098h
  254.  FG_PUTIMAGE     --    007Eh    0099h
  255.  FG_QUIET    0090h    007Fh    009Ah
  256.  FG_RECT    002Ah    0080h    009Bh
  257.  FG_RESET    0006h    0081h    009Ch
  258.  FG_RESIZE    0045h    0082h    009Dh
  259.  FG_RESTORE    005Bh    0083h    009Eh
  260.  FG_RESUME    0092h    0084h    009Fh
  261.  FG_REVIMAGE    004Bh    0085h    00A0h
  262.  FG_REVMASK    0053h    0086h    00A1h
  263.  FG_SAVE     --    0087h    00A2h
  264.  FG_SCALE     --     --    00A3h
  265.  FG_SCRLOCK    0074h    0088h    00A4h
  266.  FG_SCROLL    0067h    0089h    00A5h
  267.  FG_SETATTR    0019h    008Ah    00A6h
  268.  FG_SETBANKS     --     --    00A7h
  269.  FG_SETCAPS    0071h    008Bh    00A8h
  270.  FG_SETCLIP    0029h    008Ch    00A9h
  271.  FG_SETCOLOR    001Ah    008Dh    00AAh
  272.  FG_SETDACS    00A5h    008Eh    00ABh
  273.  FG_SETENTRY     --    008Fh    00ACh
  274.  FG_SETFUNC    009Ch    0090h    00ADh
  275.  FG_SETHPAGE    0041h    0091h    00AEh
  276.  FG_SETLINES    0011h    0092h    00AFh
  277.  FG_SETMODE    0001h    0093h    00B0h
  278.  FG_SETNUM    0073h    0094h    00B1h
  279.  FG_SETPAGE    003Dh    0095h    00B2h
  280.  FG_SETRGB    001Bh    0096h    00B3h
  281.  FG_SETVIEW     --     --    00B5h
  282.  FG_SETVPAGE    003Fh    0098h    00B6h
  283.  FG_SHEAR     --     --    00B7h
  284.  FG_SHOWFLIC     --     --    00B8h
  285.  FG_SHOWPCX     --    009Ah    00B9h
  286.  FG_SHOWPPR     --    009Bh    00BAh
  287.  FG_SHOWSPR     --    009Ch    00BBh
  288.  FG_SOUND    0088h    009Dh    00BCh
  289.  FG_SOUNDS    0089h    009Eh    00BDh
  290.  FG_SPLIT     --     --    00BEh
  291.  FG_STALL    0097h    009Fh    00BFh
  292.  FG_SUSPEND    0093h    00A0h    00C0h
  293.  FG_SVGAINIT     --    00A1h    00C1h
  294.  FG_SVGASTAT     --    00A2h    00C2h
  295.  FG_SVGAVER     --    00A3h    00C3h
  296.  FG_TCDEFINE     --    00A4h    00C4h
  297.  FG_TCMASK    005Eh    00A5h    00C5h
  298.  FG_TCXFER    005Dh    00A6h    00C6h
  299.  FG_TESTMODE    0002h    00A7h    00C7h
  300.  FG_TEXT    0032h    00A8h    00C8h
  301.  FG_TEXTC     --     --    00C9h
  302.  FG_TRANSFER    005Ch    00A9h    00CAh
  303.  FG_UNPACK     --     --    00CBh
  304.  FG_VBADDR     --     --    00CCh
  305.  FG_VBALLOC     --     --    00CDh
  306.  FG_VBCLOSE     --     --    00CEh
  307.  FG_VBCOPY     --     --    00CFh
  308.  FG_VBCUT     --     --    00D0h
  309.  FG_VBDEFINE     --     --    00D1h
  310.  FG_VBFREE     --     --    00D2h
  311.  FG_VBHANDLE     --     --    00D3h
  312.  FG_VBINIT     --     --    00D4h
  313.  FG_VBOPEN     --     --    00D5h
  314.  FG_VBPASTE     --     --    00D6h
  315.  FG_VBTCCOPY     --     --    00D7h
  316.  FG_VBTCXFER     --     --    00D8h
  317.  FG_VBUNDEF     --     --    00D9h
  318.  FG_VGASTATE     --     --    00DAh
  319.  FG_VOICE    008Ah    00AAh    00DBh
  320.  FG_VOICES    008Bh    00ABh    00DCh
  321.  FG_WAITFOR    0096h    00ACh    00DDh
  322.  FG_WAITKEY    006Dh    00ADh    00DEh
  323.  FG_WAITVR     --    00AEh    00DFh
  324.  FG_WHERE    0034h    00AFh    00E0h
  325.  FG_XALPHA    000Ch    00B0h    00E1h
  326.  FG_XCONVERT    000Eh    00B1h    00E2h
  327.  FG_XVIEW     --     --    00E3h
  328.  FG_YALPHA    000Dh    00B2h    00E4h
  329.  FG_YCONVERT    000Fh    00B3h    00E5h
  330.  FG_YVIEW     --     --    00E6h
  331. SeeAlso: #03473
  332. --------V-620001-----------------------------
  333. INT 62 u - FGDRIVER v3.03+ - "FG_ALLOCCMS" - CREATE LOGICAL VIDEO PAGE (CONV)
  334.     AX = 0001h
  335.     BX = page number (0001h-003Fh)
  336. Return: AX = status (0000h,FFFCh,FFFDh,FFFEh) (see #03473)
  337. Notes:    the FGDRIVER functions are rearranged with each major release, but
  338.       their parameters do not change (see #03474)
  339.     The only operation which is allowed on logical pages is "FG_COPYPAGE"
  340.       (see AX=0014h)
  341. SeeAlso: AX=0000h,AX=0002h,AX=0003h,AX=0014h,AX=0038h
  342. --------V-620002-----------------------------
  343. INT 62 u - FGDRIVER v3.03+ - "FG_ALLOCEMS" - CREATE LOGICAL VIDEO PAGE (EMS)
  344.     AX = 0002h
  345.     BX = page number (0001h-003Fh)
  346. Return: AX = status (0000h,FFFCh,FFFDh,FFFEh) (see #03473)
  347. Notes:    the FGDRIVER functions are rearranged with each major release, but
  348.       their parameters do not change (see #03474)
  349.     You must first call "FG_INITEMS" (see AX=005Dh) before using this
  350.       function
  351.     The only operation which is allowed on logical pages is "FG_COPYPAGE"
  352.       (see AX=0014h)
  353. SeeAlso: AX=0000h,AX=0001h,AX=0003h,AX=0014h,AX=0038h,AX=005Dh
  354. --------V-620003-----------------------------
  355. INT 62 u - FGDRIVER v3.03+ - "FG_ALLOCXMS" - CREATE LOGICAL VIDEO PAGE (XMS)
  356.     AX = 0003h
  357.     BX = page number (0001h-003Fh)
  358. Return: AX = status (0000h,FFFCh,FFFDh,FFFEh) (see #03473)
  359. Notes:    the FGDRIVER functions are rearranged with each major release, but
  360.       their parameters do not change (see #03474)
  361.     You must first call "FG_INITXMS" (see AX=0060h) before using this
  362.       function
  363.     The only operation which is allowed on logical pages is "FG_COPYPAGE"
  364.       (see AX=0014h)
  365. SeeAlso: AX=0000h,AX=0001h,AX=0002h,AX=0014h,AX=0038h,AX=0060h
  366. --------V-620004-----------------------------
  367. INT 62 u - FGDRIVER 1.10,3.03+ - "FG_AUTOMODE" - GET VIDEO MODE W/MOST FEATURES
  368.     AX = 0004h
  369. Return: AX = proposed video mode number (see #03500 at AX=00B0h)
  370. Program: FGDRIVER is the external video driver for the shareware
  371.       Fastgraph/Light by Ted Gruber Software
  372. Note:    the FGDRIVER functions are rearranged with each major release, but
  373.       their parameters do not change (see #03474)
  374. SeeAlso: AX=0005h,AX=004Bh,AX=00B0h,AX=00C1h,AX=00C7h
  375. --------V-620005-----------------------------
  376. INT 62 u - FGDRIVER v3.03+ - "FG_BESTMODE" - GET BEST VIDEO MODE GIVEN RESOLUTN
  377.     AX = 0005h
  378.     BX = horizontal resolution
  379.     CX = vertical resolution
  380.     DX = number of video pages required (both physical and virtual)
  381. Return: AX = proposed video mode number or FFFFh if no matching video mode
  382. Notes:    the FGDRIVER functions are rearranged with each major release, but
  383.       their parameters do not change (see #03474)
  384.     You must first call "FG_SVGAINIT" (see AX=00C1h) to get SVGA video
  385.       modes
  386. SeeAlso: AX=0004h,AX=004Bh,AX=00B0h,AX=00C1h,AX=00C7h
  387. --------V-620006-----------------------------
  388. INT 62 u - FGDRIVER v3.03+ - "FG_BOX" - DRAW UNFILLED RECTANGLE
  389.     AX = 0006h
  390.     BX = left column
  391.     CX = right column
  392.     DX = top row
  393.     SI = bottom row
  394. Notes:    the FGDRIVER functions are rearranged with each major release, but
  395.       their parameters do not change (see #03474)
  396.     The rectangle is drawn in screen space, respecting the clipping region,
  397.       with edges of the width specified with "FG_BOXDEPTH" (see AX=0007h)
  398.       (default = 1 is set by "FG_SETMODE")
  399.     This function has no effect in text modes
  400. SeeAlso: AX=0007h,AX=0008h,AX=000Ch,AX=0016h,AX=001Dh,AX=0026h,AX=0051h
  401. SeeAlso: AX=0055h,AX=008Fh
  402. --------V-620007-----------------------------
  403. INT 62 u - FGDRIVER v3.03+ - "FG_BOXDEPTH" - SET RECTANGLE BORDER WIDTH
  404.     AX = 0007h
  405.     BX = width of left and right edges in pixels (> 0)
  406.     CX = width of top and bottom edges in pixels (> 0)
  407. Note:    the FGDRIVER functions are rearranged with each major release, but
  408.       their parameters do not change (see #03474)
  409. SeeAlso: AX=0006h,AX=0008h,AX=0051h,AX=0055h
  410. --------V-620008-----------------------------
  411. INT 62 u - FGDRIVER v3.03+ - "FG_BOXX" - XOR HOLLOW RECTANGLE
  412.     AX = 0008h
  413.     BX = left column
  414.     CX = right column
  415.     DX = top row
  416.     SI = bottom row
  417. Notes:    the FGDRIVER functions are rearranged with each major release, but
  418.       their parameters do not change (see #03474)
  419.     The rectangle is XORed into screen space, respecting the clipping
  420.       region, with edges of the width specified with "FG_BOXDEPTH"
  421.       (see AX=0007h) (default = 1 is set by "FG_SETMODE")
  422.     This function has no effect in text modes
  423. SeeAlso: AX=0006h,AX=0007h,AX=0021h,AX=0022h,AX=0051h,AX=0055h,AX=0090h
  424. --------V-620009-----------------------------
  425. INT 62 u - FGDRIVER v3.03+ - "FG_BUTTON" - GET JOYSTICK BUTTON STATE
  426.     AX = 0009h
  427.     BX = joystick number (0001h or 0002h)
  428. Return: AX = button states
  429.         bit 0: top button pressed
  430.         bit 1: bottom button pressed
  431. Note:    the FGDRIVER functions are rearranged with each major release, but
  432.       their parameters do not change (see #03474)
  433. SeeAlso: AX=0052h,AX=0056h,AX=005Eh,AX=0062h,AX=0077h
  434. --------V-62000A-----------------------------
  435. INT 62 u - FGDRIVER v3.03+ - "FG_CAPSLOCK" - GET STATE OF CAPSLOCK KEY
  436.     AX = 000Ah
  437. Return: AX = CapsLock state (0000h off, 0001h on)
  438. Note:    the FGDRIVER functions are rearranged with each major release, but
  439.       their parameters do not change (see #03474)
  440. SeeAlso: AX=0082h,AX=00A4h,AX=00A8h,AX=00B1h
  441. --------V-62000B-----------------------------
  442. INT 62 u - FGDRIVER v3.03+ - "FG_CHGATTR" - APPLY CURRENT TEXT ATTRIB TO CHARS
  443.     AX = 000Bh
  444.     BX = number of characters to recolor
  445. Notes:    the FGDRIVER functions are rearranged with each major release, but
  446.       their parameters do not change (see #03474)
  447.     This call is ignored in graphics modes
  448.     Starting at the current text cursor position, the specified number of
  449.       characters have their attributes to the current text attribute
  450. SeeAlso: AX=000Ch,AX=003Ah,AX=00A6h
  451. --------V-62000C-----------------------------
  452. INT 62 u - FGDRIVER v3.03+ - "FG_CHGTEXT" - DISPLAY STRING AT CURSOR POSITION
  453.     AX = 000Ch
  454.     CX = length of string
  455.     ES:BX -> string to be displayed
  456. Return: text cursor updated
  457. Notes:    the FGDRIVER functions are rearranged with each major release, but
  458.       their parameters do not change (see #03474)
  459.     This call is ignored in graphics modes
  460. SeeAlso: AX=000Bh,AX=0096h
  461. --------V-62000D-----------------------------
  462. INT 62 u - FGDRIVER v3.03+ - "FG_CIRCLE" - DRAW UNFILLED CIRCLE
  463.     AX = 000Dh
  464.     BX = radius in horizontal screen space units (> 0)
  465. Notes:    the FGDRIVER functions are rearranged with each major release, but
  466.       their parameters do not change (see #03474)
  467.     The circle is drawn in screen space, centered at the current graphics
  468.       cursor position
  469.     This call is ignored in text modes
  470. SeeAlso: AX=0006h,AX=0008h,AX=000Eh,AX=0026h,AX=0093h
  471. --------V-62000E-----------------------------
  472. INT 62 u - FGDRIVER v3.03+ - "FG_CIRCLEF" - DRAW FILLED CIRCLE
  473.     AX = 000Eh
  474.     BX = radius in horizontal screen space units (> 0)
  475. Note:    the FGDRIVER functions are rearranged with each major release, but
  476.       their parameters do not change (see #03474)
  477. SeeAlso: AX=0008h,AX=000Dh,AX=0027h,AX=0092h
  478. --------V-62000F-----------------------------
  479. INT 62 u - FGDRIVER v4.02 - "FG_CLIPMAP" - DISPLAY CLIPPED IMAGE (MODE-INDEP)
  480.     AX = 000Fh
  481.     ES:BX -> bitmap
  482.     CX = width
  483.     DX = height
  484. Desc:    display a mode-independent bitmap, showing only the portion within
  485.       the current clipping limits
  486. Notes:    the FGDRIVER functions are rearranged with each major release, but
  487.       their parameters do not change (see #03474)
  488.     This call is ignored in text modes and in native EGA and VGA graphics
  489.       modes
  490.     The image is drawn with its lower left corner at the current graphics
  491.       cursor position
  492. SeeAlso: AX=0011h,AX=001Fh,AX=0034h,AX=0086h,AX=00A9h,AX=00C5h
  493. --------V-620010-----------------------------
  494. INT 62 u - FGDRIVER v4.02 - "FG_CLIPMASK" - DISPLAY CLIPPED IMAGE (MASKING MAP)
  495.     AX = 0010h
  496.     ES:BX -> array containing image stored as a masking map (see #03475)
  497.     CX = number of pixel runs in masking map
  498.     DX = width of masking map in pixels
  499. Notes:    the FGDRIVER functions are rearranged with each major release, but
  500.       their parameters do not change (see #03474)
  501.     This call is ignored in text modes and in native EGA and VGA graphics
  502.       modes
  503.     The image is drawn with its lower left corner at the current graphics
  504.       cursor position
  505. SeeAlso: AX=0011h,AX=001Fh,AX=0034h,AX=00A1h,AX=00A9h,AX=00C5h
  506. --------V-620011-----------------------------
  507. INT 62 u - FGDRIVER v4.02 - "FG_CLPIMAGE" - DISPLAY CLIPPED IMAGE (BITMAP)
  508.     AX = 0011h
  509.     ES:BX -> mode-specific bitmap
  510.     CX = width of bit map in bytes
  511.     DX = height of bit map in pixel rows
  512. Notes:    the FGDRIVER functions are rearranged with each major release, but
  513.       their parameters do not change (see #03474)
  514.     This call is ignored in text modes
  515.     The image is drawn with its lower left corner at the current graphics
  516.       cursor position
  517.     The current clipping region is used, extended to a byte boundary
  518. SeeAlso: AX=0010h,AX=0024h,AX=0036h,AX=0044h,AX=00A0h,AX=00A9h,AX=00B9h
  519. --------V-620012-----------------------------
  520. INT 62 u - FGDRIVER v4.02 - "FG_CLPRECT" - DRAW FILLED RECTANGLE IN SCREEN SPCE
  521.     AX = 0012h
  522.     BX = screen space column of left edge
  523.     CX = screen space column of right edge
  524.     DX = screen space row of top edge
  525.     SI = screen space row of bottom edge
  526. Notes:    the FGDRIVER functions are rearranged with each major release, but
  527.       their parameters do not change (see #03474)
  528.     This call is ignored in text modes
  529. SeeAlso: AX=0006h,AX=0010h,AX=0011h,AX=0023h,AX=009Bh,AX=00A9h
  530. --------V-620013-----------------------------
  531. INT 62 u - FGDRIVER v4.02 - "FG_COLORS" - GET SIMULTANEOUSLY-AVAILABLE COLORS
  532.     AX = 0013h
  533. Return: AX = number of colors available at one time
  534. Note:    the FGDRIVER functions are rearranged with each major release, but
  535.       their parameters do not change (see #03474)
  536. --------V-620014-----------------------------
  537. INT 62 u - FGDRIVER v4.02 - "FG_COPYPAGE" - TRANSFER VIDEO PAGE CONTENTS
  538.     AX = 0014h
  539.     BX = source page number (0000h-003Fh)
  540.     CX = destination page number (0000h-003Fh)
  541. Notes:    the FGDRIVER functions are rearranged with each major release, but
  542.       their parameters do not change (see #03474)
  543.     If both source and destination pages are logical pages, they must both
  544.       be located in the same type (conventional, EMS, XMS) of memory
  545. SeeAlso: AX=009Eh,AX=00A2h,AX=00C6h,AX=00CAh
  546. --------V-620015-----------------------------
  547. INT 62 u - FGDRIVER v4.02 - "FG_CURSOR" - SPECIFY WHETHER TEXT CURSR IS VISIBLE
  548.     AX = 0015h
  549.     BX = new state (0000h invisible, 0001h visible)
  550. Notes:    the FGDRIVER functions are rearranged with each major release, but
  551.       their parameters do not change (see #03474)
  552.     This call is ignored in text modes
  553. SeeAlso: AX=000Ch,AX=0054h,AX=0058h,AX=006Bh,AX=0075h,AX=0079h,AX=007Eh
  554. SeeAlso: AX=00E0h
  555. --------V-620016-----------------------------
  556. INT 62 u - FGDRIVER v4.02 - "FG_DASH" - DRAW DASHED LINE TO ABSOLUTE POSITION
  557.     AX = 0016h
  558.     BX = endpoint column
  559.     CX = endpoint row
  560.     DX = dash pattern (set bits cause drawn pixels)
  561. Notes:    the FGDRIVER functions are rearranged with each major release, but
  562.       their parameters do not change (see #03474)
  563.     This call is ignored in text modes
  564.     The starting point is the current graphics cursor position; the cursor
  565.       position is updated
  566. SeeAlso: AX=0017h,AX=001Dh,AX=008Fh
  567. --------V-620017-----------------------------
  568. INT 62 u - FGDRIVER v4.02 - "FG_DASHREL" - DRAW DASHED LINE TO RELATVE POSITION
  569.     AX = 0017h
  570.     BX = endpoint column offset
  571.     CX = endpoint row offset
  572.     DX = dash pattern (set bits cause drawn pixels)
  573. Notes:    the FGDRIVER functions are rearranged with each major release, but
  574.       their parameters do not change (see #03474)
  575.     This call is ignored in text modes
  576.     The starting point is the current graphics cursor position; the cursor
  577.       position is updated
  578. SeeAlso: AX=0016h,AX=001Eh,AX=008Fh
  579. --------V-620018-----------------------------
  580. INT 62 u - FGDRIVER v4.02 - "FG_DEFCOLOR" - ASSIGN COLOR VALUE TO COLOR INDEX
  581.     AX = 0018h
  582.     BX = color index (0000h-00FFh)
  583.     CX = new color value (0 to maximum color value for current video mode)
  584. Notes:    the FGDRIVER functions are rearranged with each major release, but
  585.       their parameters do not change (see #03474)
  586.     This call is ignored in text modes and 256-color graphics modes
  587. SeeAlso: AX=0040h,AX=0045h,AX=00AAh
  588. --------V-620019-----------------------------
  589. INT 62 u - FGDRIVER v4.02 - "FG_DEFPAGES" - DEF SRC/DEST PAGES FOR BLOCK XFERS
  590.     AX = 0019h
  591.     BX = source page
  592.     CX = destination page
  593. Desc:    specify the source and destination SVGA banks for block transfers on
  594.       extended video pages
  595. Notes:    the FGDRIVER functions are rearranged with each major release, but
  596.       their parameters do not change (see #03474)
  597.     This function is ignored if the video controller does not support
  598.       extended pages or the current video mode does not allow them
  599. SeeAlso: AX=0014h,AX=00CAh
  600. --------V-62001A-----------------------------
  601. INT 62 u - FGDRIVER v4.02 - "FG_DISPFILE" - DISPLAY STORED IMAGE
  602.     AX = 001Ah
  603.     ES:BX -> ASCIZ filename
  604.     CX = image width in pixels (> 0)
  605.     DX = image format
  606.         0000h Fastgraph standard pixel run format
  607.         0001h packed pixel run format
  608. Notes:    the FGDRIVER functions are rearranged with each major release, but
  609.       their parameters do not change (see #03474)
  610.     This call is ignored in text modes
  611.     The image is displayed with its lower left corner at the current
  612.       graphics cursor position
  613. SeeAlso: AX=001Bh,AX=001Ch,AX=00B9h,AX=00BAh,AX=00BBh
  614. --------V-62001B-----------------------------
  615. INT 62 u - FGDRIVER v4.02 - "FG_DISPLAY" - DISPLAY IMAGE (STD PIXEL RUN FORMAT)
  616.     AX = 001Bh
  617.     ES:BX -> pixel run map (pairs of bytes: color index, count)
  618.     CX = number of pixel runs to display
  619.     DX = width of image in pixels (> 0)
  620. Notes:    the FGDRIVER functions are rearranged with each major release, but
  621.       their parameters do not change (see #03474)
  622.     This call is ignored in text modes
  623.     The image is displayed with its lower left corner at the current
  624.       graphics cursor position
  625. SeeAlso: AX=001Ah,AX=001Ch,AX=00B9h,AX=00BAh,AX=00BBh
  626. --------V-62001C-----------------------------
  627. INT 62 u - FGDRIVER v4.02 - "FG_DISPLAYP" - DISPLAY IMAGE (PACKED PIXEL RUNS)
  628.     AX = 001Ch
  629.     ES:BX -> pixel run map (trios of bytes: colors, count1, count2; colors
  630.           contains the color for the first run in its high nybble and
  631.           the color for the second run in its low nybble)
  632.     CX = number of pixel runs to display
  633.     DX = width of image in pixels (> 0)
  634. Notes:    the FGDRIVER functions are rearranged with each major release, but
  635.       their parameters do not change (see #03474)
  636.     This call is ignored in text modes
  637.     The image is displayed with its lower left corner at the current
  638.       graphics cursor position
  639. SeeAlso: AX=001Ah,AX=001Bh,AX=00B9h,AX=00BAh,AX=00BBh
  640. --------V-62001D-----------------------------
  641. INT 62 u - FGDRIVER v4.02 - "FG_DRAW" - DRAW SOLID LINE TO ABSOLUTE POSITION
  642.     AX = 001Dh
  643.     BX = endpoint column
  644.     CX = endpoint row
  645. Notes:    the FGDRIVER functions are rearranged with each major release, but
  646.       their parameters do not change (see #03474)
  647.     This call is ignored in text modes
  648.     The starting point is the current graphics cursor position; the cursor
  649.       position is updated
  650. SeeAlso: AX=0016h,AX=0020h,AX=0021h,AX=0026h,AX=008Fh,AX=0090h
  651. --------V-62001E-----------------------------
  652. INT 62 u - FGDRIVER v4.02 - "FG_DRAWMAP" - DISPLAY MODE-INDEPENDENT BIT MAP
  653.     AX = 001Eh
  654.     ES:BX -> bitmap (each set bit is pixel drawn in current color)
  655.     CX = width of bitmap in bytes
  656.     DX = height of bitmap in pixel rows
  657. Note:    the FGDRIVER functions are rearranged with each major release, but
  658.       their parameters do not change (see #03474)
  659. SeeAlso: AX=0011h,AX=0024h,AX=0036h,AX=0044h,AX=0099h,AX=00A0h
  660. --------V-62001F-----------------------------
  661. INT 62 u - FGDRIVER v4.02 - "FG_DRAWMASK" - DISPLAY IMAGE (MASKING MAP)
  662.     AX = 001Fh
  663.     ES:BX -> array containing image stored as a masking map (see #03475)
  664.     CX = number of pixel runs in masking map
  665.     DX = width of masking map in pixels
  666. Notes:    the FGDRIVER functions are rearranged with each major release, but
  667.       their parameters do not change (see #03474)
  668.     This call is ignored in text modes and in native EGA and VGA graphics
  669.       modes
  670.     The image is drawn with its lower left corner at the current graphics
  671.       cursor position
  672. SeeAlso: AX=0010h,AX=001Fh,AX=00A1h,AX=00A9h
  673.  
  674. Format of FGDRIVER masking map:
  675. Offset    Size    Description    (Table 03475)
  676.  00h    BYTE    length of first "protect" run (pixels remain unchanged)
  677.  01h    BYTE    length of first "zero" run (pixels set to background color)
  678.  02h    BYTE    length of second "protect" run
  679.  03h    BYTE    length of second "zero" run
  680.     ...
  681. --------V-620020-----------------------------
  682. INT 62 u - FGDRIVER v4.02 - "FG_DRAWREL" - DRAW SOLID LINE TO RELATIVE POSITION
  683.     AX = 0020h
  684.     BX = endpoint column offset
  685.     CX = endpoint row offset
  686. Notes:    the FGDRIVER functions are rearranged with each major release, but
  687.       their parameters do not change (see #03474 at AX=0000h)
  688.     This call is ignored in text modes
  689.     The starting point is the current graphics cursor position; the cursor
  690.       position is updated
  691. SeeAlso: AX=0006h,AX=000Dh,AX=001Dh,AX=0021h,AX=0026h,AX=008Fh
  692. --------V-620021-----------------------------
  693. INT 62 u - FGDRIVER v4.02 - "FG_DRAWRELX" - XOR SOLID LINE TO RELATIVE POSITION
  694.     AX = 0021h
  695.     BX = endpoint column offset
  696.     CX = endpoint row offset
  697. Desc:    draw a solid line, XORing each pixel onto the screen
  698. Notes:    the FGDRIVER functions are rearranged with each major release, but
  699.       their parameters do not change (see #03474 at AX=0000h)
  700.     This call is ignored in text modes
  701.     The starting point is the current graphics cursor position; the cursor
  702.       position is updated
  703. SeeAlso: AX=0006h,AX=000Dh,AX=001Dh,AX=0020h,AX=0026h,AX=0090h
  704. --------V-620022-----------------------------
  705. INT 62 u - FGDRIVER v4.02 - "FG_DRAWX" - XOR SOLID LINE TO ABSOLUTE POSITION
  706.     AX = 0022h
  707.     BX = endpoint column
  708.     CX = endpoint row
  709. Desc:    draw a solid line, XORing each pixel onto the screen
  710. Notes:    the FGDRIVER functions are rearranged with each major release, but
  711.       their parameters do not change (see #03474 at AX=0000h)
  712.     This call is ignored in text modes
  713.     The starting point is the current graphics cursor position; the cursor
  714.       position is updated
  715. SeeAlso: AX=001Dh,AX=0021h,AX=008Fh
  716. --------V-620023-----------------------------
  717. INT 62 u - FGDRIVER v4.02 - "FG_DRECT" - DRAW DITHERED RECTANGLE IN SCRN SPACE
  718.     AX = 0023h
  719.     BX = screen space column of left edge
  720.     CX = screen space column of right edge
  721.     DX = screen space row of top edge
  722.     SI = screen space row of bottom edge
  723.     ES:DI -> dithering matrix (video-mode dependent)
  724. Notes:    the FGDRIVER functions are rearranged with each major release, but
  725.       their parameters do not change (see #03474 at AX=0000h)
  726.     This call is ignored in text modes
  727. SeeAlso: AX=0006h,AX=0008h,AX=0013h,AX=003Ch,AX=0089h,AX=009Bh
  728. --------V-620024-----------------------------
  729. INT 62 u - FGDRIVER v4.02 - "FG_DRWIMAGE" - DISPLAY BITMAPPED IMAGE
  730.     AX = 0024h
  731.     ES:BX -> video mode-specific bitmap
  732.     CX = width of bitmap in bytes
  733.     DX = height of bitmap in pixel rows
  734. Notes:    the FGDRIVER functions are rearranged with each major release, but
  735.       their parameters do not change (see #03474 at AX=0000h)
  736.     The image will be drawn with its lower left corner at the current
  737.       cursor position (either text or graphics)
  738. SeeAlso: AX=0011h,AX=0036h,AX=0044h,AX=0099h,AX=00A0h
  739. --------V-620025-----------------------------
  740. INT 62 u - FGDRIVER v4.02 - "FG_EGACHECK" - GET INFO ABOUT ACTIVE EGA DISPLAY
  741.     AX = 0025h
  742. Return: AX = number of 64K banks of video memory, or 0000h if no EGA or EGA
  743.           without an Enhanced Color Display
  744. Note:    the FGDRIVER functions are rearranged with each major release, but
  745.       their parameters do not change (see #03474 at AX=0000h)
  746. SeeAlso: AX=00C2h
  747. --------V-620026-----------------------------
  748. INT 62 u - FGDRIVER v4.02 - "FG_ELLIPSE" - DRAW UNFILLED ELLIPSE IN SCRN SPACE
  749.     AX = 0026h
  750.     BX = horizontal semi-axis length in screen space units
  751.     CX = vertical semi-axis length in screen space units
  752. Notes:    the FGDRIVER functions are rearranged with each major release, but
  753.       their parameters do not change (see #03474 at AX=0000h)
  754.     This call is ignored in text modes
  755.     The ellipse is centered at the current graphics cursor position
  756. SeeAlso: AX=0006h,AX=000Dh,AX=0027h,AX=008Fh,AX=0093h
  757. --------V-620027-----------------------------
  758. INT 62 u - FGDRIVER v4.02 - "FG_ELLIPSEF" - DRAW FILLED ELLIPSE IN SCREEN SPACE
  759.     AX = 0027h
  760.     BX = horizontal semi-axis length in screen space units
  761.     CX = vertical semi-axis length in screen space units
  762. Notes:    the FGDRIVER functions are rearranged with each major release, but
  763.       their parameters do not change (see #03474 at AX=0000h)
  764.     This call is ignored in text modes
  765.     The ellipse is centered at the current graphics cursor position
  766. SeeAlso: AX=0006h,AX=000Eh,AX=0026h,AX=008Fh,AX=0092h
  767. --------V-620028-----------------------------
  768. INT 62 u - FGDRIVER v4.02 - "FG_ERASE" - CLEAR THE ACTIVE VIDEO PAGE
  769.     AX = 0028h
  770. Notes:    the FGDRIVER functions are rearranged with each major release, but
  771.       their parameters do not change (see #03474 at AX=0000h)
  772.     This function sets each pixel to 0 in graphics modes, each character
  773.       cell to a blank with a gray foreground attribute in text modes
  774. SeeAlso: AX=0029h,AX=002Bh,AX=0035h
  775. --------V-620029-----------------------------
  776. INT 62 u - FGDRIVER v4.02 - "FG_FADEIN" - FADE IN HIDDEN PAGE
  777.     AX = 0029h
  778.     BX = delay (0000h = fastest possible fade-in)
  779. Notes:    the FGDRIVER functions are rearranged with each major release, but
  780.       their parameters do not change (see #03474 at AX=0000h)
  781.     The current hidden page is copied to the current visible page in small
  782.       random sections to produce a fade-in effect
  783.     This call is ignored in text modes
  784. SeeAlso: AX=0028h,AX=002Ah,AX=002Bh
  785. --------V-62002A-----------------------------
  786. INT 62 u - FGDRIVER v4.02 - "FG_FADEOUT" - FADE OUT TO CURRENT COLOR
  787.     AX = 002Ah
  788.     BX = delay (0000h = fastest possible fade-out)
  789. Notes:    the FGDRIVER functions are rearranged with each major release, but
  790.       their parameters do not change (see #03474 at AX=0000h)
  791.     The current visible page is filled with pixels of the current color in
  792.       small random sections to give a fade-out effect
  793.     This call is ignored in text modes
  794. SeeAlso: AX=0028h,AX=0029h,AX=002Bh
  795. --------V-62002B-----------------------------
  796. INT 62 u - FGDRIVER v4.02 - "FG_FILLPAGE" - FILL THE ACTIVE VIDEO PAGE
  797.     AX = 002Bh
  798. Desc:    fill the active video page with pixels of the current color (graphics
  799.       modes) or the block character DBh with the current character
  800.       attributes (text modes)
  801. Note:    the FGDRIVER functions are rearranged with each major release, but
  802.       their parameters do not change (see #03474 at AX=0000h)
  803. SeeAlso: AX=0028h,AX=0029h,AX=002Ah
  804. --------V-62002C-----------------------------
  805. INT 62 u - FGDRIVER v4.02 - "FG_FINDPAGE" - FIND AVAILABLE VIRTUAL/LOGICAL PAGE
  806.     AX = 002Ch
  807. Return: AX = first available page number (virtual or logical page)
  808. Note:    the FGDRIVER functions are rearranged with each major release, but
  809.       their parameters do not change (see #03474 at AX=0000h)
  810. SeeAlso: AX=0028h
  811. --------V-62002D-----------------------------
  812. INT 62 u - FGDRIVER v4.02 - "FG_FLICDONE" - CLOSE FLIC FILE
  813.     AX = 002Dh
  814.     ES:BX -> context descriptor (see AX=0030h)
  815. Return: nothing
  816. Note:    the FGDRIVER functions are rearranged with each major release, but
  817.       their parameters do not change (see #03474 at AX=0000h)
  818. SeeAlso: AX=002Eh,AX=0030h
  819. --------V-62002E-----------------------------
  820. INT 62 u - FGDRIVER v4.02 - "FG_FLICHEAD" - READ FLI/FLC FILE HEADER
  821.     AX = 002Eh
  822.     ES:BX -> FLICHEAD variable pointer record (see #03477)
  823. Return: AX = status (see #03476)
  824. Note:    the FGDRIVER functions are rearranged with each major release, but
  825.       their parameters do not change (see #03474 at AX=0000h)
  826. SeeAlso: AX=002Dh,AX=002Fh,AX=0030h,AX=0032h
  827.  
  828. (Table 03476)
  829. Values for FGDRIVER FLIC processing status:
  830.  0000h    successful
  831.  FFFEh    not an FLI or FLC file
  832.  FFFFh    file not found
  833.  
  834. Format of FGDRIVER FLICHEAD variable pointer record:
  835. Offset    Size    Description    (Table 03477)
  836.  00h    WORD    segment of ASCIZ FLI/FLC file name
  837.  02h    WORD    offset of ASCIZ FLI/FLC file name
  838.  04h    WORD    segment of buffer for 128-byte file header
  839.  06h    WORD    offset of buffer for 128-byte file header
  840. --------V-62002F-----------------------------
  841. INT 62 u - FGDRIVER v4.02 - "FG_FLICMODE" - GET OPTIMAL VIDEO MODE FOR FLI/FLC
  842.     AX = 002Fh
  843.     ES:BX -> 128-byte buffer containing FLI/FLC file header (see AX=002Eh)
  844. Return: AX = optimal 256-color graphics mode number
  845.         FFFFh if invalid file header
  846. Note:    the FGDRIVER functions are rearranged with each major release, but
  847.       their parameters do not change (see #03474 at AX=0000h)
  848. SeeAlso: AX=002Eh,AX=0030h
  849. --------V-620030-----------------------------
  850. INT 62 u - FGDRIVER v4.02 - "FG_FLICOPEN" - OPEN FLI/FLC FILE
  851.     AX = 0030h
  852.     ES:BX -> FLICOPEN variable pointer record (see #03478)
  853. Return: AX = status (see #03476)
  854. Note:    the FGDRIVER functions are rearranged with each major release, but
  855.       their parameters do not change (see #03474 at AX=0000h)
  856. SeeAlso: AX=002Dh,AX=002Eh,AX=002Fh,AX=0030h,AX=0031h,AX=0032h
  857.  
  858. Format of FGDRIVER FLICOPEN variable pointer record:
  859. Offset    Size    Description    (Table 03478)
  860.  00h    WORD    segment of ASCIZ FLI/FLC file name
  861.  02h    WORD    offset of ASCIZ FLI/FLC file name
  862.  04h    WORD    segment of buffer for 16-byte file context descriptor
  863.  06h    WORD    offset of buffer for 16-byte file context descriptor
  864. --------V-620031-----------------------------
  865. INT 62 u - FGDRIVER v4.02 - "FG_FLICPLAY" - DISPLAY NEXT FRAME(S) IN FLI/FLC
  866.     AX = 0031h
  867.     ES:BX -> context descriptor (see AX=0030h)
  868.     CX = number of frames to display starting at current frame
  869.     DX = control flags (see #03479)
  870. Return: AX = number of frames displayed
  871. Note:    the FGDRIVER functions are rearranged with each major release, but
  872.       their parameters do not change (see #03474 at AX=0000h)
  873. SeeAlso: AX=0030h,AX=0033h,AX=00B8h
  874.  
  875. Bitfields for FGDRIVER FLI/FLC control flags:
  876. Bit(s)    Description    (Table 03479)
  877.  0    skip inter-frame delay specified in FLI/FLC header
  878.  1    display relative to current graphics position
  879.  2    dipslay image from the FG_IMAGEBUF buffer instead of file
  880. --------V-620032-----------------------------
  881. INT 62 u - FGDRIVER v4.02 - "FG_FLICSIZE" - GET IMAGE SIZE
  882.     AX = 0032h
  883.     ES:BX -> FLICSIZE variable pointer record (see #03480)
  884. Return: image height/width buffers updated; height is set to FFFFh on error
  885. Note:    the FGDRIVER functions are rearranged with each major release, but
  886.       their parameters do not change (see #03474 at AX=0000h)
  887. SeeAlso: AX=002Eh,AX=0030h
  888.  
  889. Format of FGDRIVER FLICSIZE variable pointer record:
  890. Offset    Size    Description    (Table 03480)
  891.  00h    WORD    segment of buffer for 128-byte FLI/FLC file header
  892.  02h    WORD    offset of buffer for 128-byte FLI/FLC file header
  893.  04h    WORD    segment of WORD buffer for image width in pixels
  894.  06h    WORD    offset of WORD buffer for image width in pixels
  895.  08h    WORD    segment of WORD buffer for image height in pixels
  896.  0Ah    WORD    offset of WORD buffer for image height in pixels
  897. --------V-620033-----------------------------
  898. INT 62 u - FGDRIVER v4.02 - "FG_FLICSKIP" - SKIP FRAME(S) IN FLI/FLC FILE
  899.     AX = 0033h
  900.     ES:BX -> context descriptor (see AX=0030h)
  901.     CX = number of frames to skip
  902.         reset to first frame if skip count is negative
  903. Return: AX = number of frames skipped (may be less than requested if EOF)
  904.         0000h if resetting to first frame
  905. Note:    the FGDRIVER functions are rearranged with each major release, but
  906.       their parameters do not change (see #03474 at AX=0000h)
  907. SeeAlso: AX=0030h,AX=0031h
  908. --------V-620034-----------------------------
  909. INT 62 u - FGDRIVER v4.02 - "FG_FLIPMASK" - DISPLAY INV CLIPPED IMAGE (MASKMAP)
  910.     AX = 0034h
  911.     ES:BX -> array containing image stored as a masking map (see #03475)
  912.     CX = number of pixel runs in masking map
  913.     DX = width of masking map in pixels
  914. Notes:    the FGDRIVER functions are rearranged with each major release, but
  915.       their parameters do not change (see #03474 at AX=0000h)
  916.     This call is ignored in text modes and in native EGA and VGA graphics
  917.       modes
  918.     The image is drawn with its lower left corner at the current graphics
  919.       cursor position
  920. SeeAlso: AX=000Fh,AX=001Fh,AX=0036h,AX=00A1h,AX=00A5h,AX=00C5h
  921. --------V-620035-----------------------------
  922. INT 62 u - FGDRIVER v4.02 - "FG_FLOOD" - FLOOD FILL ARBITRARY CLOSED REGION
  923.     AX = 0035h
  924.     BX = starting column
  925.     CX = starting row
  926. Desc:    fill the bounded region around the specified point (respecting clipping
  927.       region) with the currrent color
  928. Notes:    the FGDRIVER functions are rearranged with each major release, but
  929.       their parameters do not change (see #03474 at AX=0000h)
  930.     This function is ignored in text modes
  931. SeeAlso: AX=0028h,AX=0085h
  932. --------V-620036-----------------------------
  933. INT 62 u - FGDRIVER v4.02 - "FG_FLPIMAGE" - DISPLAY INV CLIPPED IMAGE (BITMAP)
  934.     AX = 0036h
  935.     ES:BX -> mode-specific bitmap
  936.     CX = width of bit map in bytes
  937.     DX = height of bit map in pixel rows
  938. Notes:    the FGDRIVER functions are rearranged with each major release, but
  939.       their parameters do not change (see #03474 at AX=0000h)
  940.     This call is ignored in text modes
  941.     The image is drawn with its lower left corner at the current graphics
  942.       cursor position
  943.     The current clipping region is used, extended to a byte boundary
  944. SeeAlso: AX=0011h,AX=0024h,AX=0034h,AX=0044h,AX=00A0h,AX=00A9h,AX=00B9h
  945. --------V-620037-----------------------------
  946. INT 62 u - FGDRIVER v4.02 - "FG_FONTSIZE" - SPECIFY FONT SIZE FOR TEXT OUTPUT
  947.     AX = 0037h
  948.     BX = desired character height in scan lines (8, 14, 16)
  949. Notes:    the FGDRIVER functions are rearranged with each major release, but
  950.       their parameters do not change (see #03474 at AX=0000h)
  951.     This call is ignored if the current mode is not a VGA or SVGA graphics
  952.       mode, or the specified character height is not 8, 14, or 16
  953. SeeAlso: AX=0096h
  954. --------V-620038-----------------------------
  955. INT 62 u - FGDRIVER v4.02 - "FG_FREEPAGE" - FREE VIRTUAL OR LOGICAL VIDEO PAGE
  956.     AX = 0038h
  957.     BX = page number (0000h-003Fh)
  958. Return: AX = status (0000h,0001h,0007h,0009h) (see #03473)
  959. Note:    the FGDRIVER functions are rearranged with each major release, but
  960.       their parameters do not change (see #03474 at AX=0000h)
  961. SeeAlso: AX=0000h,AX=0001h,AX=0002h,AX=0003h
  962. --------V-620039-----------------------------
  963. INT 62 u - FGDRIVER v4.02 - "FG_GETADDR" - GET SEGMENT OF ACTIVE VIDEO PAGE
  964.     AX = 0039h
  965. Return: AX = segment of active video page
  966. Note:    the FGDRIVER functions are rearranged with each major release, but
  967.       their parameters do not change (see #03474 at AX=0000h)
  968. SeeAlso: AX=0042h,AX=00ACh
  969. --------V-62003A-----------------------------
  970. INT 62 u - FGDRIVER v4.02 - "FG_GETATTR" - GET CHARACTER ATTRIB FOR POSITION
  971.     AX = 003Ah
  972.     BX = row
  973.     CX = column
  974. Return: AX = character attribute at specified location on active video page
  975. Notes:    the FGDRIVER functions are rearranged with each major release, but
  976.       their parameters do not change (see #03474 at AX=0000h)
  977.     This call is ignored in graphics modes
  978. SeeAlso: AX=000Bh,AX=003Dh,AX=0040h,AX=00A6h
  979. --------V-62003B-----------------------------
  980. INT 62 u - FGDRIVER v4.02 - "FG_GETBANKS" - GET SVGA READ AND WRITE BANKS
  981.     AX = 003Bh
  982.     ES:BX -> GETBANKS variable pointer record (see #03481)
  983. Return: nothing
  984. Note:    the FGDRIVER functions are rearranged with each major release, but
  985.       their parameters do not change (see #03474 at AX=0000h)
  986. SeeAlso: AX=00A7h
  987.  
  988. Format of FGDRIVER GETBANKS variable pointer record:
  989. Offset    Size    Description    (Table 03481)
  990.  00h    WORD    segment of WORD buffer for read bank number
  991.  02h    WORD    offset of WORD buffer for read bank number
  992.  04h    WORD    segment of WORD buffer for write bank number
  993.  06h    WORD    offset of WORD buffer for write bank number
  994. --------V-62003C-----------------------------
  995. INT 62 u - FGDRIVER v4.02 - "FG_GETBLOCK" - GRAB RECTANGLE OF DISPLAY
  996.     AX = 003Ch
  997.     ES:BX -> buffer for screen contents
  998.     CX = leftmost column
  999.     DX = rightmost column
  1000.     SI = top row
  1001.     DI = bottom row
  1002. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1003.       their parameters do not change (see #03474 at AX=0000h)
  1004.     In text modes, coordinates are character positions; in graphics modes,
  1005.       they are defined in screen space, and the left and right edges are
  1006.       adjusted to a byte boundary if necessary
  1007.     Use "FG_IMAGESIZ" (see AX=005Ch) to determine the required buffer size
  1008. SeeAlso: AX=0044h,AX=005Ch,AX=0098h
  1009. --------V-62003D-----------------------------
  1010. INT 62 u - FGDRIVER v4.02 - "FG_GETCHAR" - GET CHARACTER FOR SCREEN POSITION
  1011.     AX = 003Dh
  1012.     BX = row
  1013.     CX = column
  1014. Return: AX = character at specified location on active video page
  1015. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1016.       their parameters do not change (see #03474 at AX=0000h)
  1017.     This call is ignored in graphics modes
  1018. SeeAlso: AX=000Bh,AX=003Ah,AX=0096h,AX=00A6h,AX=00C8h
  1019. --------V-62003E-----------------------------
  1020. INT 62 u - FGDRIVER v4.02 - "FG_GETCLIP" - GET CLIPPING REGION IN SCREEN SPACE
  1021.     AX = 003Eh
  1022.     ES:BX -> GETCLIP variable pointer record (see #03482)
  1023. Return: variables specifed by GETCLIP structure updated
  1024. Note:    the FGDRIVER functions are rearranged with each major release, but
  1025.       their parameters do not change (see #03474 at AX=0000h)
  1026. SeeAlso: AX=00CAh
  1027.  
  1028. Format of FGDRIVER GETCLIP variable pointer record:
  1029. Offset    Size    Description    (Table 03482)
  1030.  00h    WORD    segment of WORD buffer for minimum X coordinate (left edge)
  1031.  02h    WORD    offset of WORD buffer for minimum X coordinate (left edge)
  1032.  04h    WORD    segment of WORD buffer for maximum X coordinate (right edge)
  1033.  06h    WORD    offset of WORD buffer for maximum X coordinate (right edge)
  1034.  08h    WORD    segment of WORD buffer for minimum Y coordinate (top edge)
  1035.  0Ah    WORD    offset of WORD buffer for minimum Y coordinate (top edge)
  1036.  0Ch    WORD    segment of WORD buffer for maximum Y coordinate (bottom edge)
  1037.  0Eh    WORD    offset of WORD buffer for maximum Y coordinate (bottom edge)
  1038. --------V-62003F-----------------------------
  1039. INT 62 u - FGDRIVER v4.02 - "FG_GETCLOCK" - GET CLOCK TICKS SINCE MIDNIGHT
  1040.     AX = 003Fh
  1041. Return: DX:AX = number of clock ticks since midnight
  1042. Note:    the FGDRIVER functions are rearranged with each major release, but
  1043.       their parameters do not change (see #03474 at AX=0000h)
  1044. SeeAlso: INT 1A/AH=00h
  1045. --------V-620040-----------------------------
  1046. INT 62 u - FGDRIVER v4.02 - "FG_GETCOLOR" - GET CURRENT TEXT ATTRIBUTE
  1047.     AX = 0040h
  1048. Return: AX = current text attribute or color index (graphics modes)
  1049. Note:    the FGDRIVER functions are rearranged with each major release, but
  1050.       their parameters do not change (see #03474 at AX=0000h)
  1051. SeeAlso: AX=000Bh,AX=003Ah,AX=00A6h
  1052. --------V-620041-----------------------------
  1053. INT 62 u - FGDRIVER v4.02 - "FG_GETDACS" - GET VIDEO DAC CONTENTS
  1054.     AX = 0041h
  1055.     CX = number of DAC registers to return (0001h to 0100h)
  1056.     DX = starting DAC register number (0000h to 00FFh)
  1057.     ES:BX -> buffer for DAC red/green/blue triples
  1058. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1059.       their parameters do not change (see #03474 at AX=0000h)
  1060.     The register number wraps back to zero after FFh
  1061. SeeAlso: AX=004Eh,AX=0086h,AX=00ABh
  1062. --------V-620042-----------------------------
  1063. INT 62 u - FGDRIVER v4.02 - "FG_GETENTRY" - GET PAGE TYPE AND ADDRESS
  1064.     AX = 0042h
  1065.     ES:BX -> variable pointer record (see #03483)
  1066.     CX = page number (00h-3Fh)
  1067. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1068.       their parameters do not change (see #03474 at AX=0000h)
  1069.     Page addresses are segments for pages stored in conventional memory
  1070.       (including physical and virtual pages), and EMS or XMS handles for
  1071.       pages stored in EMS or XMS
  1072. SeeAlso: AX=0000h,AX=00ACh
  1073.  
  1074. Format of FGDRIVER GETENTRY variable pointer record:
  1075. Offset    Size    Description    (Table 03483)
  1076.  00h    WORD    segment of WORD buffer for page address
  1077.  02h    WORD    offset of WORD buffer for page address
  1078.  04h    WORD    segment of WORD buffer for page type (se #03484)
  1079.  06h    WORD    offset of WORD buffer for page type
  1080.  
  1081. (Table 03484)
  1082. Values for FGDRIVER page type:
  1083.  0000h    unallocated
  1084.  0001h    physical
  1085.  0002h    virtual
  1086.  0003h    logical page, stored in expanded memory (EMS)
  1087.  0004h    logical page, stored in extended memory (XMS)
  1088.  0005h    logical page, stored in conventional memory
  1089. --------V-620043-----------------------------
  1090. INT 62 u - FGDRIVER v4.02 - "FG_GETHPAGE" - GET CURRENT HIDDEN VIDEO PAGE NUM
  1091.     AX = 0043h
  1092. Return: AX = current hidden video page number (0000h-003Fh)
  1093. Note:    the FGDRIVER functions are rearranged with each major release, but
  1094.       their parameters do not change (see #03474 at AX=0000h)
  1095. SeeAlso: AX=004Ch,AX=0050h,AX=00AEh
  1096. --------V-620044-----------------------------
  1097. INT 62 u - FGDRIVER v4.02 - "FG_GETIMAGE" - STORE IMAGE AS BITMAP
  1098.     AX = 0044h
  1099.     ES:BX -> buffer for video mode-specific bitmap
  1100.     CX = width of bitmap in bytes
  1101.     DX = height of bitmap in pixel rows
  1102. Note:    the FGDRIVER functions are rearranged with each major release, but
  1103.       their parameters do not change (see #03474 at AX=0000h)
  1104. SeeAlso: AX=0011h,AX=0024h,AX=0036h,AX=0099h,AX=00A0h
  1105. --------V-620045-----------------------------
  1106. INT 62 u - FGDRIVER v4.02 - "FG_GETINDEX" - GET COLOR VALUE FOR COLOR INDEX
  1107.     AX = 0045h
  1108.     BX = color index (0000h to 00FFh)
  1109. Return: AX = color value for specified color index
  1110. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1111.       their parameters do not change (see #03474 at AX=0000h)
  1112.     This call returns the value passed to it in text and 256-color
  1113.       graphics modes
  1114. SeeAlso: AX=0018h,AX=0040h
  1115. --------V-620046-----------------------------
  1116. INT 62 u - FGDRIVER v4.02 - "FG_GETKEY" - GET NEXT KEYSTROKE
  1117.     AX = 0046h
  1118.     ES:BX -> variable pointer record (see #03485)
  1119. Return: (after next keystroke if no typeahead) variables updated
  1120. Note:    the FGDRIVER functions are rearranged with each major release, but
  1121.       their parameters do not change (see #03474 at AX=0000h)
  1122. SeeAlso: AX=000Ah,AX=0063h,AX=0069h,AX=00DEh,INT 16/AH=00h
  1123.  
  1124. Format of FGDRIVER GETKEY variable pointer record:
  1125. Offset    Size    Description    (Table 03485)
  1126.  00h    WORD    segment of BYTE buffer for ASCII keycode
  1127.  02h    WORD    offset of BYTE buffer for ASCII keycode
  1128.  04h    WORD    segment of BYTE buffer for extended keycode
  1129.  06h    WORD    offset of BYTE buffer for extended keycode
  1130. --------V-620047-----------------------------
  1131. INT 62 u - FGDRIVER v4.02 - "FG_GETLINES" - GET TEXT ROWS FOR CURR VIDEO MODE
  1132.     AX = 0047h
  1133. Return: AX = number of text rows on screen in current video mode
  1134. Note:    the FGDRIVER functions are rearranged with each major release, but
  1135.       their parameters do not change (see #03474 at AX=0000h)
  1136. SeeAlso: AX=00AFh,AX=00C2h
  1137. --------V-620048-----------------------------
  1138. INT 62 u - FGDRIVER v4.02 - "FG_GETMAP" - STORE IMAGE AS MODE-INDEPENDNT BITMAP
  1139.     AX = 0048h
  1140.     ES:BX -> buffer for video mode-independent bitmap
  1141.     CX = width of bitmap in bytes
  1142.     DX = height of bitmap in pixel rows
  1143. Return: each bit in bitmap is set if corresponding pixel is of the current
  1144.       color, cleared otherwise
  1145. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1146.       their parameters do not change (see #03474 at AX=0000h)
  1147.     This call is ignored in text modes
  1148. SeeAlso: AX=0011h,AX=001Eh,AX=0024h
  1149. --------V-620049-----------------------------
  1150. INT 62 u - FGDRIVER v4.02 - "FG_GETMAXX" - GET MAXIMUM COLUMN IN SCREEN SPACE
  1151.     AX = 0049h
  1152. Return: AX = maximum X coordinate in screen space
  1153.         (or character space if in text mode)
  1154. Note:    the FGDRIVER functions are rearranged with each major release, but
  1155.       their parameters do not change (see #03474 at AX=0000h)
  1156. SeeAlso: AX=004Ah,AX=00C1h
  1157. --------V-62004A-----------------------------
  1158. INT 62 u - FGDRIVER v4.02 - "FG_GETMAXY" - GET MAXIMUM ROW IN SCREEN SPACE
  1159.     AX = 004Ah
  1160. Return: AX = maximum Y coordinate in screen space
  1161.         (or character space if in text mode)
  1162. Note:    the FGDRIVER functions are rearranged with each major release, but
  1163.       their parameters do not change (see #03474 at AX=0000h)
  1164. SeeAlso: AX=0049h,AX=00C1h
  1165. --------V-62004B-----------------------------
  1166. INT 62 u - FGDRIVER v4.02 - "FG_GETMODE" - GET CURRENT VIDEO MODE NUMBER
  1167.     AX = 004Bh
  1168.     ES:BX -> WORD ???
  1169. Return: AX = current video mode number
  1170. Note:    the FGDRIVER functions are rearranged with each major release, but
  1171.       their parameters do not change (see #03474 at AX=0000h)
  1172. SeeAlso: AX=00B0h
  1173. --------V-62004C-----------------------------
  1174. INT 62 u - FGDRIVER v4.02 - "FG_GETPAGE" - GET ACTIVE VIDEO PAGE NUMBER
  1175.     AX = 004Ch
  1176. Return: AX = active video page (0000h-003Fh)
  1177. Note:    the FGDRIVER functions are rearranged with each major release, but
  1178.       their parameters do not change (see #03474 at AX=0000h)
  1179. SeeAlso: AX=0039h,AX=0042h,AX=0043h,AX=0050h,AX=00B2h
  1180. --------V-62004D-----------------------------
  1181. INT 62 u - FGDRIVER v4.02 - "FG_GETPIXEL" - GET COLOR OF SPECIFIED PIXEL
  1182.     AX = 004Dh
  1183.     BX = column in screen space
  1184.     CX = row in screen space
  1185. Return: AX = color value of pixel (0 to num_colors-1)
  1186.         0000h in text modes
  1187. Note:    the FGDRIVER functions are rearranged with each major release, but
  1188.       their parameters do not change (see #03474 at AX=0000h)
  1189. SeeAlso: AX=003Ah,AX=003Dh,AX=008Fh,AX=0090h
  1190. --------V-62004E-----------------------------
  1191. INT 62 u - FGDRIVER v4.02 - "FG_GETRGB" - GET VIDEO DAC REGISTER CONTENTS
  1192.     AX = 004Eh
  1193.     ES:BX -> variable pointer record (see #03486)
  1194.     CX = DAC register number
  1195. Return: variables updated
  1196. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1197.       their parameters do not change (see #03474 at AX=0000h)
  1198.     This call is ignored in text modes and CGA/EGA video modes (since
  1199.       they do not use DAC registers)
  1200. SeeAlso: AX=0041h,AX=0086h,AX=00ABh
  1201.  
  1202. Format of FGDRIVER GETRGB variable pointer record:
  1203. Offset    Size    Description    (Table 03486)
  1204.  00h    WORD    segment of WORD buffer for red component of DAC register
  1205.  02h    WORD    offset of WORD buffer for red component
  1206.  04h    WORD    segment of WORD buffer for green component of DAC register
  1207.  06h    WORD    offset of WORD buffer for green component
  1208.  08h    WORD    segment of WORD buffer for blue component of DAC register
  1209.  0Ah    WORD    offset of WORD buffer for blue component
  1210. --------V-62004F-----------------------------
  1211. INT 62 u - FGDRIVER v4.02 - "FG_GETVIEW" - GET VIEWPORT EXTREME LIMITS
  1212.     AX = 004Fh
  1213.     ES:BX -> variable pointer record (see #03487)
  1214. Return: indicated variables updated
  1215. Note:    the FGDRIVER functions are rearranged with each major release, but
  1216.       their parameters do not change (see #03474 at AX=0000h)
  1217. SeeAlso: AX=00B5h
  1218.  
  1219. Format of FGDRIVER GETVIEW variable pointer record:
  1220. Offset    Size    Description    (Table 03487)
  1221.  00h    WORD    segment of WORD buffer for viewport left edge (viewport units)
  1222.  02h    WORD    offset of WORD buffer for viewport left edge (viewport units)
  1223.  04h    WORD    segment of WORD buffer for viewport right edge (viewport units)
  1224.  06h    WORD    offset of WORD buffer for viewport right edge (viewport units)
  1225.  08h    WORD    segment of WORD buffer for viewport top edge (viewport units)
  1226.  0Ah    WORD    offset of WORD buffer for viewport top edge (viewport units)
  1227.  0Ch    WORD    segment of WORD buffer for viewport bottom edge (viewp. units)
  1228.  0Eh    WORD    offset of WORD buffer for viewport bottom edge (viewp. units)
  1229.  10h    WORD    segment of WORD buffer for viewport left edge (screen space)
  1230.  12h    WORD    offset of WORD buffer for viewport left edge (screen space)
  1231.  14h    WORD    segment of WORD buffer for viewport right edge (screen space)
  1232.  16h    WORD    offset of WORD buffer for viewport right edge (screen space)
  1233.  18h    WORD    segment of WORD buffer for viewport top edge (screen space)
  1234.  1Ah    WORD    offset of WORD buffer for viewport top edge (screen space)
  1235.  1Ch    WORD    segment of WORD buffer for viewport bottom edge (screen space)
  1236.  1Eh    WORD    offset of WORD buffer for viewport bottom edge (screen space)
  1237. --------V-620050-----------------------------
  1238. INT 62 u - FGDRIVER v4.02 - "FG_GETVPAGE" - GET VISIBLE VIDEO PAGE NUMBER
  1239.     AX = 0050h
  1240. Return: AX = visible video page (0000h-003Fh)
  1241. Note:    the FGDRIVER functions are rearranged with each major release, but
  1242.       their parameters do not change (see #03474 at AX=0000h)
  1243. SeeAlso: AX=0043h,AX=004Ch,AX=00B6h
  1244. --------V-620051-----------------------------
  1245. INT 62 u - FGDRIVER v4.02 - "FG_GETXBOX" - GET WIDTH OF VERTICAL BOX LINES
  1246.     AX = 0051h
  1247. Return: AX = width (in pixels) of left and right edges of rectangles
  1248. Note:    the FGDRIVER functions are rearranged with each major release, but
  1249.       their parameters do not change (see #03474 at AX=0000h)
  1250. SeeAlso: AX=0006h,AX=0007h,AX=0008h,AX=006Bh
  1251. --------V-620052-----------------------------
  1252. INT 62 u - FGDRIVER v4.02 - "FG_GETXJOY" - GET HORIZONTAL POSITION OF JOYSTICK
  1253.     AX = 0052h
  1254.     BX = joystick number (0001h or 0002h)
  1255. Return: AX = horizontal position of joystick
  1256.         FFFFh if joystick uninitialized or not present
  1257. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1258.       their parameters do not change (see #03474 at AX=0000h)
  1259.     The actual coordinates are processor- and joystick-dependent
  1260.     You must call "FG_INITJOY" (AX=005Eh) before using this function
  1261. SeeAlso: AX=0009h,AX=0056h,AX=005Eh,AX=0062h,AX=0077h
  1262. --------V-620053-----------------------------
  1263. INT 62 u - FGDRIVER v4.02 - "FG_GETXJUST" - GET HORIZONTAL JUSTIFICATION
  1264.     AX = 0053h
  1265. Return: AX = string justification
  1266.         0000h strings are centered around current graphics X position
  1267.         0001h strings are right-justified at current graphics X position
  1268.         FFFFh strings are left-justified at current graphics X position
  1269. Note:    the FGDRIVER functions are rearranged with each major release, but
  1270.       their parameters do not change (see #03474 at AX=0000h)
  1271. SeeAlso: AX=006Ch,AX=007Bh
  1272. --------V-620054-----------------------------
  1273. INT 62 u - FGDRIVER v4.02 - "FG_GETXPOS" - GET GRAPHICS CURSOR COLUMN
  1274.     AX = 0054h
  1275. Return: AX = screen space X coordinate of graphics cursor position
  1276. Note:    the FGDRIVER functions are rearranged with each major release, but
  1277.       their parameters do not change (see #03474 at AX=0000h)
  1278. SeeAlso: AX=0058h,AX=007Eh,AX=007Fh
  1279. --------V-620055-----------------------------
  1280. INT 62 u - FGDRIVER v4.02 - "FG_GETYBOX" - GET WIDTH OF HORIZONTAL BOX LINES
  1281.     AX = 0055h
  1282. Return: AX = width (in pixels) of top and bottom edges of rectangles
  1283. Note:    the FGDRIVER functions are rearranged with each major release, but
  1284.       their parameters do not change (see #03474 at AX=0000h)
  1285. SeeAlso: AX=0006h,AX=0007h,AX=0008h,AX=0063h
  1286. --------V-620056-----------------------------
  1287. INT 62 u - FGDRIVER v4.02 - "FG_GETYJOY" - GET VERTICAL POSITION OF JOYSTICK
  1288.     AX = 0056h
  1289.     BX = joystick number (0001h or 0002h)
  1290. Return: AX = vertical position of joystick
  1291.         FFFFh if joystick uninitialized or not present
  1292. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1293.       their parameters do not change (see #03474 at AX=0000h)
  1294.     The actual coordinates are processor- and joystick-dependent
  1295.     You must call "FG_INITJOY" (AX=005Eh) before using this function
  1296. SeeAlso: AX=0009h,AX=0052h,AX=005Eh,AX=0062h,AX=0077h
  1297. --------V-620057-----------------------------
  1298. INT 62 u - FGDRIVER v4.02 - "FG_GETYJUST" - GET VERTICAL JUSTIFICATION
  1299.     AX = 0057h
  1300. Return: AX = string justification
  1301.         0000h strings are centered around current graphics Y position
  1302.         0001h strings have top edge at current graphics Y position
  1303.         FFFFh strings have bottom edge at current graphics Y position
  1304. Note:    the FGDRIVER functions are rearranged with each major release, but
  1305.       their parameters do not change (see #03474 at AX=0000h)
  1306. SeeAlso: AX=0053h,AX=0065h
  1307. --------V-620058-----------------------------
  1308. INT 62 u - FGDRIVER v4.02 - "FG_GETYPOS" - GET GRAPHICS CURSOR ROW
  1309.     AX = 0058h
  1310. Return: AX = screen space Y coordinate of graphics cursor position
  1311. Note:    the FGDRIVER functions are rearranged with each major release, but
  1312.       their parameters do not change (see #03474 at AX=0000h)
  1313. SeeAlso: AX=0054h,AX=007Eh,AX=007Fh
  1314. --------V-620059-----------------------------
  1315. INT 62 u - FGDRIVER v4.02 - "FG_HUSH" - STOP ASYNCHRONOUS SOUND IMMEDIATELY
  1316.     AX = 0059h
  1317. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1318.       their parameters do not change (see #03474 at AX=0000h)
  1319.     This function immediately stops any sounds started with "FG_MUSICB",
  1320.       "FG_SOUNDS", or "FG_VOICES"; it is ignored if no asynchronous sound
  1321.       is playing
  1322. SeeAlso: AX=005Ah,AX=0081h,AX=00BDh,AX=00DCh
  1323. --------V-62005A-----------------------------
  1324. INT 62 u - FGDRIVER v4.02 - "FG_HUSHNEXT" - STOP ASYNCHRONOUS SOUND
  1325.     AX = 005Ah
  1326. Program: FGDRIVER is the external video driver for the shareware
  1327.       Fastgraph/Light by Ted Gruber Software
  1328. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1329.       their parameters do not change (see #03474 at AX=0000h)
  1330.     This function stops any sounds started with "FG_MUSICB", "FG_SOUNDS",
  1331.       or "FG_VOICES" after the current repetition completes; it is ignored
  1332.       unless asynchronous sound is continuous
  1333. SeeAlso: AX=0059h,AX=0081h,AX=00BDh,AX=00DCh
  1334. --------V-62005B-----------------------------
  1335. INT 62 u - FGDRIVER v4.02 - "FG_IMAGEBUF" - SPECIFY TEMPORARY IMAGE BUFFER
  1336.     AX = 005Bh
  1337.     ES:BX -> buffer to be used when creating or displaying GIF/PCX/PPR/SPR
  1338.           images
  1339.     CX = size of buffer in bytes or 0000h to use internal buffer
  1340. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1341.       their parameters do not change (see #03474 at AX=0000h)
  1342.     Fastgraph's internal buffer is 4096 bytes; this function allows the
  1343.       application to define a larger buffer which will typically speed
  1344.       processing
  1345. SeeAlso: AX=006Ch,AX=006Dh,AX=006Eh,AX=00B9h,AX=00BAh,AX=00BBh
  1346. --------V-62005C-----------------------------
  1347. INT 62 u - FGDRIVER v4.02 - "FG_IMAGESIZ" - DETERMINE IMAGE STORAGE REQUIREMENT
  1348.     AX = 005Ch
  1349.     BX = image width in pixels
  1350.     CX = image height in pixels
  1351. Note:    the FGDRIVER functions are rearranged with each major release, but
  1352.       their parameters do not change (see #03474 at AX=0000h)
  1353. Return: DX:AX = size in bytes of mode-specific bitmap for current video mode
  1354. SeeAlso: AX=003Ch,AX=0098h
  1355. --------V-62005D-----------------------------
  1356. INT 62 u - FGDRIVER v4.02 - "FG_INITEMS" - INITIALIZE EXPANDED MEMORY USE
  1357.     AX = 005Dh
  1358. Return: AX = status
  1359.         0000h successful
  1360.         FFFFh expanded memory manager inaccessible or not installed
  1361. Note:    the FGDRIVER functions are rearranged with each major release, but
  1362.       their parameters do not change (see #03474 at AX=0000h)
  1363. SeeAlso: AX=0002h,AX=0060h"v4.02"
  1364. --------V-62005E-----------------------------
  1365. INT 62 u - FGDRIVER v4.02 - "FG_INITJOY" - INITIALIZE JOYSTICK USE
  1366.     AX = 005Eh
  1367.     BX = joystick number (0001h or 0002h)
  1368. Return: AX = status
  1369.         0000h successful
  1370.         FFFFh joystick not connected or no game port
  1371. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1372.       their parameters do not change (see #03474 at AX=0000h)
  1373.     Fastgraph assumes that the requested joystick is centered at the time
  1374.       this function is called
  1375. SeeAlso: AX=0009h,AX=0052h,AX=0056h,AX=0062h,AX=0077h
  1376. --------V-62005F-----------------------------
  1377. INT 62 u - FGDRIVER v4.02 - "FG_INITPM"??? - (NOT IMPLEMENTED)
  1378.     AX = 005Fh
  1379.     ???
  1380. Return: ???
  1381. Note:    the FGDRIVER functions are rearranged with each major release, but
  1382.       their parameters do not change (see #03474 at AX=0000h)
  1383. --------V-620060-----------------------------
  1384. INT 62 u - FGDRIVER v1.10 only - "FG_DISPPCX" - DISPLAY PCX FILE
  1385.     AX = 0060h
  1386.     ES:BX -> ASCIZ filename
  1387.     CX = flags
  1388.         bit 0: use current palette rather than PCX file's palette
  1389.         bits 1-15 reserved (0)
  1390. Return: AX = status
  1391.         0000h success
  1392.         0001h file not found
  1393.         0002h file is not a valid PCX file
  1394. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1395.       their parameters do not change (see #03474 at AX=0000h)
  1396.     This call is ignored in text modes and Hercules low-resolution graphics
  1397.     The image is displayed with its upper left corner at the current
  1398.       graphics cursor position
  1399. SeeAlso: AX=00B9h
  1400. --------V-620060-----------------------------
  1401. INT 62 u - FGDRIVER v4.02 - "FG_INITXMS" - INITIALIZE EXTENDED MEMORY USE
  1402.     AX = 0060h
  1403. Return: AX = status
  1404.         0000h successful
  1405.         FFFFh extended memory manager inaccessible or not installed
  1406. Note:    the FGDRIVER functions are rearranged with each major release, but
  1407.       their parameters do not change (see #03474 at AX=0000h)
  1408. SeeAlso: AX=0003h,AX=005Dh
  1409. --------V-620061-----------------------------
  1410. INT 62 u - FGDRIVER v4.02 - "FG_INSIDE" - CHECK IF POINT INSIDE CONVEX POLYGON
  1411.     AX = 0061h
  1412.     ES:BX -> vertex array
  1413.     CX = number of vertices
  1414.     DX = screen space column of point to test
  1415.     SI = screen space row of point to test
  1416. Return: AX = result
  1417.         0000h point is outside polygon
  1418.         0001h point is inside polygon
  1419.         undefined if not a convex polygon
  1420. Note:    the FGDRIVER functions are rearranged with each major release, but
  1421.       their parameters do not change (see #03474 at AX=0000h)
  1422. SeeAlso: AX=0092h,AX=0093h,AX=0094h
  1423. --------V-620062-----------------------------
  1424. INT 62 u - FGDRIVER v4.02 - "FG_INTJOY" - GET KEYCODES CORRESP TO JOYSTICK POS
  1425.     AX = 0062h
  1426.     CX = joystick number (0001h or 0002h)
  1427.     ES:BX -> variable pointer record (see #03488)
  1428. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1429.       their parameters do not change (see #03474 at AX=0000h)
  1430.     If the indicated joystick has not been initialized with AX=008Eh, both
  1431.       the button code and joystick position will be set to 00h
  1432.     If either button is pressed, a button code of 0Dh is returned;
  1433.       otherwise, a button code of 00h is returned
  1434. SeeAlso: AX=0009h,AX=0052h,AX=0046h,AX=005Eh,AX=0077h
  1435.  
  1436. Format of FGDRIVER INTJOY variable pointer record:
  1437. Offset    Size    Description    (Table 03488)
  1438.  00h    WORD    segment of BYTE buffer for button code
  1439.  02h    WORD    offset of BYTE buffer for button code
  1440.  04h    WORD    segment of BYTE buffer for joystick position
  1441.  06h    WORD    offset of BYTE buffer for joystick position
  1442. --------V-620063-----------------------------
  1443. INT 62 u - FGDRIVER v4.02 - "FG_INTKEY" - GET KEYSTROKE, NO WAIT
  1444.     AX = 0063h
  1445.     ES:BX -> variable pointer record (see #03489)
  1446. Return: variables updated
  1447. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1448.       their parameters do not change (see #03474 at AX=0000h)
  1449.     If the keyboard buffer is empty, both the ASCII and extended keycodes
  1450.       are set to 00h
  1451. SeeAlso: AX=000Ah,AX=0046h,AX=0069h,AX=00DEh,INT 16/AH=01h
  1452.  
  1453. Format of FGDRIVER INTKEY variable pointer record:
  1454. Offset    Size    Description    (Table 03489)
  1455.  00h    WORD    segment of BYTE buffer for ASCII keycode
  1456.  02h    WORD    offset of BYTE buffer for ASCII keycode
  1457.  04h    WORD    segment of BYTE buffer for extended keycode
  1458.  06h    WORD    offset of BYTE buffer for extended keycode
  1459. --------V-620064-----------------------------
  1460. INT 62 u - FGDRIVER v4.02 - "FG_INVERT" - INVERT ORIENTATION OF BITMAP
  1461.     AX = 0064h
  1462.     ES:BX -> bitmap
  1463.     CX = width of bitmap in bytes
  1464.     DX = height of bitmap in pixel rows
  1465. Return: nothing
  1466. Note:    the FGDRIVER functions are rearranged with each major release, but
  1467.       their parameters do not change (see #03474 at AX=0000h)
  1468. --------V-620065-----------------------------
  1469. INT 62 u - FGDRIVER v4.02 - "FG_JUSTIFY" - SET TEXT OUTPUT JUSTIFICATION
  1470.     AX = 0065h
  1471.     BX = horizontal justification
  1472.           (00h centered, 01h right-justified, FFh left-justified)
  1473.     CX = vertical justification
  1474.           (00h centered, 01h top of characters, FFh bottom of chars)
  1475. Note:    the FGDRIVER functions are rearranged with each major release, but
  1476.       their parameters do not change (see #03474 at AX=0000h)
  1477. SeeAlso: AX=000Ch,AX=0037h,AX=0053h,AX=0057h,AX=0096h
  1478. --------V-620066-----------------------------
  1479. INT 62 u - FGDRIVER v4.02 - "FG_KBINIT" - ENABLE/DISABLE LOW-LEVEL KBD HANDLER
  1480.     AX = 0066h
  1481.     BX = new state (0000h disabled, 0001h enabled)
  1482. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1483.       their parameters do not change (see #03474 at AX=0000h)
  1484.     When the low-level handler is enabled, "FG_GETKEY", "FG_INTKEY",
  1485.       "FG_WAITKEY", and all other functions calling DOS or BIOS keyboard
  1486.       services become unavailable
  1487. SeeAlso: AX=0067h,AX=0068h,AX=0069h
  1488. --------V-620067-----------------------------
  1489. INT 62 u - FGDRIVER v4.02 - "FG_KBLAST" - GET MOST RECENT SCANCODE PROCESSED
  1490.     AX = 0067h
  1491. Return: AX = scancode for keypress most recently processed by FastGraph's
  1492.           low-level keyboard handler, or 0000h if no keys since FG_KBINIT
  1493. Note:    the FGDRIVER functions are rearranged with each major release, but
  1494.       their parameters do not change (see #03474 at AX=0000h)
  1495. SeeAlso: AX=0066h,AX=0068h,AX=0069h
  1496. --------V-620068-----------------------------
  1497. INT 62 u - FGDRIVER v4.02 - "FG_KBRESET" - RESET LOW-LEVEL KEYBOARD HANDLER
  1498.     AX = 0068h
  1499. Note:    the FGDRIVER functions are rearranged with each major release, but
  1500.       their parameters do not change (see #03474 at AX=0000h)
  1501. SeeAlso: AX=0066h,AX=0067h,AX=0069h
  1502. --------V-620069-----------------------------
  1503. INT 62 u - FGDRIVER v4.02 - "FG_KBTEST" - CHECK WHETHER SPECIFIED KEY PRESSED
  1504.     AX = 0069h
  1505.     BX = scan code of desired key
  1506. Return: AX = state
  1507.         0000h key is not pressed
  1508.         0001h key is currently pressed
  1509. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1510.       their parameters do not change (see #03474 at AX=0000h)
  1511.     The low-level keyboard handler must have been enabled with AX=0066h
  1512. SeeAlso: AX=0066h,AX=0067h,INT 16/AH=01h
  1513. --------V-62006A-----------------------------
  1514. INT 62 u - FGDRIVER v4.02 - "FG_LOADPCX" - LOAD .PCX INTO ACTIVE VIRTUAL BUFFER
  1515.     AX = 006Ah
  1516.     ES:BX -> ASCIZ filename for PCX image
  1517.     CX = control flags
  1518.         bit 0: use current palette, overriding stored .PCX palette
  1519.         bit 1: load at current graphics position, not stored position
  1520.         bit 2: load image from FG_IMAGEBUF buffer instead of .PCX file
  1521. Return: AX = status
  1522.         0000h successful
  1523.         0001h file not found
  1524.         0002h not a .PCX file
  1525. Note:    the FGDRIVER functions are rearranged with each major release, but
  1526.       their parameters do not change (see #03474 at AX=0000h)
  1527. SeeAlso: AX=006Ch,AX=00B9h,AX=00D5h
  1528. --------V-62006B-----------------------------
  1529. INT 62 u - FGDRIVER v4.02 - "FG_LOCATE" - SET TEXT-MODE CURSOR POSITION
  1530.     AX = 006Bh
  1531.     BX = row
  1532.     CX = column
  1533. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1534.       their parameters do not change (see #03474 at AX=0000h)
  1535.     There are only eight text cursors shared by successive groups of
  1536.       eight video pages (pages 0, 8, 16, ... share one cursor, 1, 9, ...
  1537.       share the second, etc)
  1538. SeeAlso: AX=0054h,AX=0058h,AX=007Eh,AX=00E0h
  1539. --------V-62006C-----------------------------
  1540. INT 62 u - FGDRIVER v4.02 - "FG_MAKEPCX" - CREATE PCX FILE FROM SCREEN WINDOW
  1541.     AX = 006Ch
  1542.     BX = left edge in screen space units
  1543.     CX = right edge in screen space units
  1544.     DX = top edge in screen space units
  1545.     SI = bottom edge in screen space units
  1546.     ES:DI -> ASCIZ filename of PCX file to create
  1547. Return: AX = status
  1548.         0000h successful
  1549.         0001h file not created
  1550. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1551.       their parameters do not change (see #03474 at AX=0000h)
  1552.     The PCX file is created from the specified region of the active video
  1553.       page; the left and right edges are adjusted to a byte boundary if
  1554.       necessary
  1555.     If the specified file already exists, it is overwritten
  1556.     This call is ignored in text and Hercules low-resolution graphics modes
  1557. SeeAlso: AX=005Bh,AX=006Dh,AX=006Ah,AX=006Eh,AX=00B9h,AX=00BAh,AX=00BBh
  1558. --------V-62006D-----------------------------
  1559. INT 62 u - FGDRIVER v4.02 - "FG_MAKEPPR" - CREATE PACKED PIXEL RUN FILE
  1560.     AX = 006Dh
  1561.     BX = left edge in screen space units
  1562.     CX = right edge in screen space units
  1563.     DX = top edge in screen space units
  1564.     SI = bottom edge in screen space units
  1565.     ES:DI -> ASCIZ filename of PPR file to create
  1566. Return: AX = status
  1567.         0000h successful
  1568.         0001h file not created
  1569. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1570.       their parameters do not change (see #03474 at AX=0000h)
  1571.     The PPR file is created from the specified region of the active video
  1572.       page; the left and right edges are adjusted to byte boundaries if
  1573.       necessary
  1574.     If the specified file already exists, it is overwritten
  1575.     This call is ignored in text modes
  1576. SeeAlso: AX=005Bh,AX=006Ch,AX=006Eh,AX=00B9h,AX=00BAh,AX=00BBh
  1577. --------V-62006E-----------------------------
  1578. INT 62 u - FGDRIVER v4.02 - "FG_MAKESPR" - CREATE STANDARD PIXEL RUN FILE
  1579.     AX = 006Eh
  1580.     BX = left edge in screen space units
  1581.     CX = right edge in screen space units
  1582.     DX = top edge in screen space units
  1583.     SI = bottom edge in screen space units
  1584.     ES:DI -> ASCIZ filename of SPR file to create
  1585. Return: AX = status
  1586.         0000h successful
  1587.         0001h file not created
  1588. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1589.       their parameters do not change (see #03474 at AX=0000h)
  1590.     The SPR file is created from the specified region of the active video
  1591.       page; the left and right edges are adjusted to byte boundaries if
  1592.       necessary
  1593.     If the specified file already exists, it is overwritten
  1594.     This call is ignored in text modes
  1595. SeeAlso: AX=005Bh,AX=006Ch,AX=006Dh,AX=00B9h,AX=00BAh,AX=00BBh
  1596. --------V-62006F-----------------------------
  1597. INT 62 u - FGDRIVER v4.02 - "FG_MAPRGB" - MAP COLOR COMPONENTS INTO PALETTE VAL
  1598.     AX = 006Fh
  1599.     BX = red component
  1600.     CX = green component
  1601.     DX = blue component
  1602. Return: AX = mode-specific palette value corresponding to specified components
  1603. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1604.       their parameters do not change (see #03474 at AX=0000h)
  1605.     This function is only meaningful in 16-color graphics modes
  1606. SeeAlso: AX=004Eh,AX=00B3h
  1607. --------V-620070-----------------------------
  1608. INT 62 u - FGDRIVER v4.02 - "FG_MEASURE" - GET DELAY UNITS PER CLOCK TICK
  1609.     AX = 0070h
  1610. Return: AX = delay units per clock tick (processor-dependent)
  1611. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1612.       their parameters do not change (see #03474 at AX=0000h)
  1613.     These delay units are used by "FG_STALL" (see AX=00BFh)
  1614. SeeAlso: AX=00BFh
  1615. --------V-620071-----------------------------
  1616. INT 62 u - FGDRIVER v4.02 - "FG_MEMAVAIL" - QUERY AMOUNT OF FREE MEMORY
  1617.     AX = 0071h
  1618. Return: DX:AX = number of bytes of conventional memory available
  1619. Note:    the FGDRIVER functions are rearranged with each major release, but
  1620.       their parameters do not change (see #03474 at AX=0000h)
  1621. SeeAlso: AX=005Dh,AX=0072h
  1622. --------V-620072-----------------------------
  1623. INT 62 u - FGDRIVER v4.02 - "FG_MEMORY" - GET SIZE OF VIDEO MEMORY
  1624.     AX = 0072h
  1625. Return: AX = size of video memory in KB
  1626. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1627.       their parameters do not change (see #03474 at AX=0000h)
  1628.     You must first call "FG_SVGAINIT" (see AX=00C1h) before using this
  1629.       function
  1630. SeeAlso: AX=0071h
  1631. --------V-620073-----------------------------
  1632. INT 62 u - FGDRIVER v4.02 - "FG_MOUSE256" - DEFINE 256-COLOR MOUSE CURSOR
  1633.     AX = 0073h
  1634.     ES:BX -> 512-byte cursor definition
  1635.     CX = X offset of hot-spot within mouse cursor
  1636.     DX = Y offset of hot-spot within mouse cursor
  1637. Return: nothing
  1638. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1639.       their parameters do not change (see #03474 at AX=0000h)
  1640.     the cursor definition array consists of 256 bytes defining the 16x16
  1641.       screen mask, followed by another 256 bytes definining the 16x16
  1642.       cursor mask
  1643. SeeAlso: AX=0074h,AX=0075h,AX=007Bh
  1644. --------V-620074-----------------------------
  1645. INT 62 u - FGDRIVER v4.02 - "FG_MOUSEBUT" - GET MOUSE BUTTON PRESS/RELEASE CNTS
  1646.     AX = 0074h
  1647.     CX = mouse button (1 = left press, 2 = right press, 3 = middle press,
  1648.           -1=left release, -2=right release, -3=middle release)
  1649.     ES:BX -> variable pointer record (see #03490)
  1650. Return: variables updated
  1651. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1652.       their parameters do not change (see #03474 at AX=0000h)
  1653.     This function returns the count of presses or releases since the last
  1654.       call to this function; if the count is zero, row and column will
  1655.       also be zero
  1656. SeeAlso: AX=0075h,AX=0077h,AX=007Ah
  1657.  
  1658. Format of FGDRIVER MOUSEBUT variable pointer record:
  1659. Offset    Size    Description    (Table 03490)
  1660.  00h    WORD    segment of WORD buffer for press/release count
  1661.  02h    WORD    offset of WORD buffer for press/release count
  1662.  04h    WORD    segment of WORD buffer for screen space col of last press/rls
  1663.  06h    WORD    offset of WORD buffer for screen space col of last press/rels
  1664.  08h    WORD    segment of WORD buffer for screen space row of last press/rls
  1665.  0Ah    WORD    offset of WORD buffer for screen space row of last press/rls
  1666. --------V-620075-----------------------------
  1667. INT 62 u - FGDRIVER v4.02 - "FG_MOUSECUR" - SPECIFY TEXT-MODE MOUSE CURSOR
  1668.     AX = 0075h
  1669.     BX = screen mask
  1670.     CX = cursor mask
  1671. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1672.       their parameters do not change (see #03474 at AX=0000h)
  1673.     This call is ignored in graphics modes
  1674. SeeAlso: AX=007Bh,AX=007Dh
  1675. --------V-620076-----------------------------
  1676. INT 62 u - FGDRIVER v4.02 - "FG_MOUSEFIN" - UNHOOK FASTGRAPH MOUSE HANDLER
  1677.     AX = 0076h
  1678. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1679.       their parameters do not change (see #03474 at AX=0000h)
  1680.     This function should be called before switching back to text mode if
  1681.       "FG_MOUSEINI" was called while in an SVGA graphics mode
  1682. SeeAlso: AX=0077h
  1683. --------V-620077-----------------------------
  1684. INT 62 u - FGDRIVER v4.02 - "FG_MOUSEINI" - INITIALIZE MOUSE SUPPORT
  1685.     AX = 0077h
  1686. Return: AX = status
  1687.         0002h two-button mouse
  1688.         0003h three-button mouse
  1689.         FFFFh initialization failed
  1690. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1691.       their parameters do not change (see #03474 at AX=0000h)
  1692.     After this call, the mouse cursor is invisible
  1693. SeeAlso: AX=0076h,AX=0078h,AX=007Ch
  1694. --------V-620078-----------------------------
  1695. INT 62 u - FGDRIVER v4.02 - "FG_MOUSELIM" - SPECIFY MOUSE CURSOR LIMITS
  1696.     AX = 0078h
  1697.     BX = left-most position allowed for mouse cursor
  1698.     CX = right-most position allowed
  1699.     DX = top-most position allowed
  1700.     SI = bottom-most position allowed
  1701. Note:    the FGDRIVER functions are rearranged with each major release, but
  1702.       their parameters do not change (see #03474 at AX=0000h)
  1703. SeeAlso: AX=0077h,AX=0079h,INT 33/AX=0007h,INT 33/AX=0008h
  1704. --------V-620079-----------------------------
  1705. INT 62 u - FGDRIVER v4.02 - "FG_MOUSEMOV" - SET MOUSE CURSOR POSITION
  1706.     AX = 0079h
  1707.     BX = new column
  1708.     CX = new row
  1709. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1710.       their parameters do not change (see #03474 at AX=0000h)
  1711.     This function will not move the mouse cursor outside the bounding box
  1712.       specified with AX=009Bh
  1713. SeeAlso: AX=0078h,AX=007Ah,INT 33/AX=0004h
  1714. --------V-62007A-----------------------------
  1715. INT 62 u - FGDRIVER v4.02 - "FG_MOUSEPOS" - GET CURRENT MOUSE POSITION
  1716.     AX = 007Ah
  1717.     ES:BX -> variable pointer record (see #03491)
  1718. Note:    the FGDRIVER functions are rearranged with each major release, but
  1719.       their parameters do not change (see #03474 at AX=0000h)
  1720. SeeAlso: AX=0079h
  1721.  
  1722. Format of FGDRIVER MOUSEPOS variable pointer record:
  1723. Offset    Size    Description    (Table 03491)
  1724.  00h    WORD    segment of WORD buffer for mouse column
  1725.  02h    WORD    offset of WORD buffer for mouse column
  1726.  04h    WORD    segment of WORD buffer for mouse row
  1727.  06h    WORD    offset of WORD buffer for mouse row
  1728.  08h    WORD    segment of WORD buffer for button status
  1729.  0Ah    WORD    offset of WORD buffer for button status
  1730. Note:    button status: bit 0 = left button, bit 1 = right, bit 2 = middle
  1731. --------V-62007B-----------------------------
  1732. INT 62 u - FGDRIVER v4.02 - "FG_MOUSEPTR" - SPECIFY GRAPH-MODE MOUSE CURSOR
  1733.     AX = 007Bh
  1734.     ES:BX -> masks (16-byte screen mask followed by 16-byte cursor mask)
  1735.     CX = X offset of hot spot from upper left corner
  1736.     DX = Y offset of hot spot from upper left corner
  1737. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1738.       their parameters do not change (see #03474 at AX=0000h)
  1739.     This call is ignored in text modes
  1740. SeeAlso: AX=0073h,AX=0075h,INT 33/AX=0009h
  1741. --------V-62007C-----------------------------
  1742. INT 62 u - FGDRIVER v4.02 - "FG_MOUSESPD" - SET MOUSE CURSOR SPEED
  1743.     AX = 007Ch
  1744.     BX = horizontal mickeys per eight pixels of movement (default 16)
  1745.     CX = vertical mickeys per eight pixels of movement (default 16)
  1746. Note:    the FGDRIVER functions are rearranged with each major release, but
  1747.       their parameters do not change (see #03474 at AX=0000h)
  1748. SeeAlso: INT 33/AX=000Fh,INT 33/AX=001Ah
  1749. --------V-62007D-----------------------------
  1750. INT 62 u - FGDRIVER v4.02 - "FG_MOUSEVIS" - SET MOUSE CURSOR VISIBILITY
  1751.     AX = 007Dh
  1752.     BX = new state (0000h invisible, 0001h visible)
  1753. Note:    the FGDRIVER functions are rearranged with each major release, but
  1754.       their parameters do not change (see #03474 at AX=0000h)
  1755. SeeAlso: AX=0077h,INT 33/AX=0001h,INT 33/AX=0002h
  1756. --------V-62007E-----------------------------
  1757. INT 62 u - FGDRIVER v4.02 - "FG_MOVE" - SET GRAPHICS CURSOR POSITION
  1758.     AX = 007Eh
  1759.     BX = new column
  1760.     CX = new row
  1761. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1762.       their parameters do not change (see #03474 at AX=0000h)
  1763.     This call is ignored in text modes
  1764. SeeAlso: AX=0054h,AX=0058h,AX=006Bh,AX=0079h,AX=007Fh,AX=00E0h
  1765. --------V-62007F-----------------------------
  1766. INT 62 u - FGDRIVER v4.02 - "FG_MOVEREL" - ADJUST GRAPHICS CURSOR POSITION
  1767.     AX = 007Fh
  1768.     BX = column offset
  1769.     CX = row offset
  1770. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1771.       their parameters do not change (see #03474 at AX=0000h)
  1772.     This call is ignored in text modes
  1773. SeeAlso: AX=0054h,AX=0058h,AX=007Eh
  1774. --------V-620080-----------------------------
  1775. INT 62 u - FGDRIVER v4.02 - "FG_MUSIC" - PLAY SERIES OF NOTES
  1776.     AX = 0080h
  1777.     ES:BX -> '$'-terminated music string in BASIC PLAY format
  1778. Return: after music completed
  1779. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1780.       their parameters do not change (see #03474 at AX=0000h)
  1781.     This call is ignored if asynchronous sound (AX=00A5h,AX=00A8h,
  1782.       AX=00AAh) is already in progress
  1783. SeeAlso: AX=0081h,AX=00BCh,AX=00DBh
  1784. --------V-620081-----------------------------
  1785. INT 62 u - FGDRIVER v4.02 - "FG_MUSICB" - PLAY SERIES OF NOTES IN BACKGROUND
  1786.     AX = 0081h
  1787.     CX = number of repetitions (negative = continuous play)
  1788.     ES:BX -> '$'-terminated music string in BASIC PLAY format
  1789. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1790.       their parameters do not change (see #03474 at AX=0000h)
  1791.     This call is ignored if asynchronous sound (AX=00A5h,AX=00A8h,
  1792.       AX=00AAh) is already in progress
  1793. SeeAlso: AX=0059h,AX=0081h,AX=00BDh,AX=00DCh
  1794. --------V-620082-----------------------------
  1795. INT 62 u - FGDRIVER v4.02 - "FG_NUMLOCK" - GET STATE OF NUMLOCK KEY
  1796.     AX = 0082h
  1797. Return: AX = NumLock state (0000h off, 0001h on)
  1798. Note:    the FGDRIVER functions are rearranged with each major release, but
  1799.       their parameters do not change (see #03474 at AX=0000h)
  1800. SeeAlso: AX=000Ah,AX=00A4h,AX=00A8h,AX=00B1h
  1801. --------V-620083-----------------------------
  1802. INT 62 u - FGDRIVER v4.02 - "FG_PACK" - CONVERT PIXEL-PER-BYTE TO PACKED BITMAP
  1803.     AX = 0083h
  1804.     ES:BX -> variable pointer record (see #03492)
  1805.     CX = width of bitmap in pixels
  1806.     DX = height of bitmap in pixels
  1807. Return: result bitmap buffer updated
  1808. SeeAlso: AX=00CBh
  1809.  
  1810. Format of FGDRIVER PACK variable pointer record:
  1811. Offset    Size    Description    (Table 03492)
  1812.  00h    WORD    segment of source (mode-independent) bitmap
  1813.  02h    WORD    offset of source (mode-independent) bitmap
  1814.  04h    WORD    segment of buffer for result (mode-specific) bitmap
  1815.  06h    WORD    offset of buffer for result (mode-specific) bitmap
  1816. --------V-620084-----------------------------
  1817. INT 62 u - FGDRIVER v4.02 - "FG_PAGESIZE" - GET VIDEO PAGE SIZE FOR CURR MODE
  1818.     AX = 0084h
  1819. Return: DX:AX = page size in bytes
  1820. Note:    the FGDRIVER functions are rearranged with each major release, but
  1821.       their parameters do not change (see #03474 at AX=0000h)
  1822. SeeAlso: AX=0072h
  1823. --------V-620085-----------------------------
  1824. INT 62 u - FGDRIVER v4.02 - "FG_PAINT" - FLOOD CLOSED REGION WITH COLOR
  1825.     AX = 0085h
  1826.     BX = column
  1827.     CX = row
  1828. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1829.       their parameters do not change (see #03474 at AX=0000h)
  1830.     This function fills an arbitrary closed region around the specified
  1831.       point with the current color; the screen edges are not considered
  1832.       region boundaries
  1833.     This call is ignored in text modes
  1834. SeeAlso: AX=0035h
  1835. --------V-620086-----------------------------
  1836. INT 62 u - FGDRIVER v4.02 - "FG_PALETTE" - SET PALETTE / SET VIDEO DAC REGISTER
  1837.     AX = 0086h
  1838. ---CGA 4-color graphics---
  1839.     BX = CGA paletee number
  1840.     CX = background color
  1841. ---CGA 2-color graphics---
  1842.     BX ignored
  1843.     CX = foreground color
  1844. ---16-color graphics---
  1845.     BX = palette register number
  1846.     CX = palette value
  1847. ---256-color graphics---
  1848.     BX = DAC register number
  1849.     CX =  DAC value
  1850. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1851.       their parameters do not change (see #03474 at AX=0000h)
  1852.     This function is ignored in text modes and Hercules graphics modes
  1853.     Few EGA/VGA adapters correctly set the foreground color in CGA mode 6
  1854. SeeAlso: AX=0041h,AX=004Eh,AX=0087h,AX=00ABh
  1855. --------V-620087-----------------------------
  1856. INT 62 u - FGDRIVER v4.02 - "FG_PALETTES" - SET ALL PALETTE REGISTERS
  1857.     AX = 0087h
  1858.     ES:BX -> array of 16 WORDs containing values for palette registers
  1859.           (or first 16 DAC registers in 256-color modes)
  1860. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1861.       their parameters do not change (see #03474 at AX=0000h)
  1862.     This function is ignored in text modes, CGA and Hercules graphics modes
  1863. SeeAlso: AX=0041h,AX=004Eh,AX=0086h,AX=00ABh
  1864. --------V-620088-----------------------------
  1865. INT 62 u - FGDRIVER v4.02 - "FG_PAN" - SET SCREEN ORIGIN
  1866.     AX = 0088h
  1867.     BX = new column for screen origin
  1868.     CX = new row for screen origin
  1869. Note:    the FGDRIVER functions are rearranged with each major release, but
  1870.       their parameters do not change (see #03474 at AX=0000h)
  1871. SeeAlso: AX=00B2h
  1872. --------V-620089-----------------------------
  1873. INT 62 u - FGDRIVER v4.02 - "FG_PATTERN" - SPECIFY DISPLAY PATTERN FOR COLOR
  1874.     AX = 0089h
  1875.     BX = index of pattern to define
  1876.     CX = number of predefined display pattern
  1877. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1878.       their parameters do not change (see #03474 at AX=0000h)
  1879.     When displaying a pixel run map, Fastgraph uses the pattern associated
  1880.       with each color index rather than displaying the actual color
  1881.     This call has no effect in text and 256-color graphics modes
  1882. SeeAlso: AX=0023h,AX=0045h
  1883. --------V-62008A-----------------------------
  1884. INT 62 u - FGDRIVER v4.02 - "FG_PCXHEAD" - GET PCX FILE HEADER
  1885.     AX = 008Ah
  1886.     ES:BX -> variable pointer record (see #03493)
  1887. Return: AX = status
  1888.         0000h successful
  1889.         FFFEh not a PCX file
  1890.         FFFFh file does not exist
  1891. Note:    the FGDRIVER functions are rearranged with each major release, but
  1892.       their parameters do not change (see #03474 at AX=0000h)
  1893. SeeAlso: AX=008Bh,AX=00B9h
  1894.  
  1895. Format of FGDRIVER PCXHEAD variable pointer record:
  1896. Offset    Size    Description    (Table 03493)
  1897.  00h    WORD    segment of ASCIZ filename
  1898.  02h    WORD    offset of ASCIZ filename
  1899.  04h    WORD    segment of 128-byte buffer for PCX header
  1900.  06h    WORD    offset of 128-byte buffer for PCX header
  1901. --------V-62008B-----------------------------
  1902. INT 62 u - FGDRIVER v4.02 - "FG_PCXMODE" - GET OPTIMAL VIDEO MODE FOR DISPLAY
  1903.     AX = 008Bh
  1904.     ES:BX -> PCX header (see AX=008Ah)
  1905. Return: AX = optimal video mode for PCX file
  1906.         FFFEh not a valid PCX header
  1907.         FFFFh unable to determine compatible video mode
  1908. Note:    the FGDRIVER functions are rearranged with each major release, but
  1909.       their parameters do not change (see #03474 at AX=0000h)
  1910. SeeAlso: AX=008Ah,AX=00B9h
  1911. --------V-62008C-----------------------------
  1912. INT 62 u - FGDRIVER v4.02 - "FG_PCXPAL" - GET PALETTE STORED IN PCX FILE
  1913.     AX = 008Ch
  1914.     ES:BX -> variable pointer record (see #03494)
  1915. Return: AX = number of colors in palette (16 or 256) or
  1916.         FFFEh not a valid PCX file
  1917.         FFFFh file not found
  1918. Note:    the FGDRIVER functions are rearranged with each major release, but
  1919.       their parameters do not change (see #03474 at AX=0000h)
  1920. SeeAlso: AX=008Dh
  1921.  
  1922. Format of FGDRIVER PCXPAL variable pointer record:
  1923. Offset    Size    Description    (Table 03494)
  1924.  00h    WORD    segment of ASCIZ .PCX filename
  1925.  02h    WORD    offset of ASCIZ .PCX filename
  1926.  04h    WORD    segment of buffer for .PCX palette RGB triples
  1927.  06h    WORD    offset of buffer for .PCX palette RGB triples
  1928. Note:    the buffer for the palette must hold at least three times as many bytes
  1929.       as there are colors in the palette
  1930. SeeAlso: #03495
  1931. --------V-62008D-----------------------------
  1932. INT 62 u - FGDRIVER v4.02 - "FG_PCXRANGE" - GET EXTENT OF PCX IMAGE
  1933.     AX = 008Dh
  1934.     ES:BX -> variable pointer record (see #03495)
  1935. Return: indicated variables updated; if the indicated header is not valid,
  1936.       all of the coordinate variables are set to FFFFh
  1937. Note:    the FGDRIVER functions are rearranged with each major release, but
  1938.       their parameters do not change (see #03474 at AX=0000h)
  1939. SeeAlso: AX=008Ch
  1940.  
  1941. Format of FGDRIVER PCXRANGE variable pointer record:
  1942. Offset    Size    Description    (Table 03495)
  1943.  00h    WORD    segment of 128-byte PCX file header
  1944.  02h    WORD    offset of 128-byte PCX file header
  1945.  04h    WORD    segment of WORD buffer for X coordinate of image's left edge
  1946.  04h    WORD    offset of WORD buffer for X coordinate of image's left edge
  1947.  08h    WORD    segment of WORD buffer for X coordinate of image's right edge
  1948.  0Ah    WORD    offset of WORD buffer for X coordinate of image's right edge
  1949.  0Ch    WORD    segment of WORD buffer for Y coordinate of image's top edge
  1950.  0Eh    WORD    offset of WORD buffer for Y coordinate of image's top edge
  1951.  10h    WORD    segment of WORD buffer for X coordinate of image's bottom edge
  1952.  12h    WORD    offset of WORD buffer for X coordinate of image's bottom edge
  1953. SeeAlso: #03494
  1954. --------V-62008E-----------------------------
  1955. INT 62 u - FGDRIVER v4.02 - "FG_PLAYING" - DETERMINE WHETHER ASYNC SOUND ACTIVE
  1956.     AX = 008Eh
  1957. Return: AX = sound state (0 = no asynchronous sound, 1 = async sound playing)
  1958. Note:    the FGDRIVER functions are rearranged with each major release, but
  1959.       their parameters do not change (see #03474 at AX=0000h)
  1960. SeeAlso: AX=0059h,AX=0081h,AX=00BDh,AX=00DCh
  1961. --------V-62008F-----------------------------
  1962. INT 62 u - FGDRIVER v4.02 - "FG_POINT" - DISPLAY A PIXEL
  1963.     AX = 008Fh
  1964.     BX = column
  1965.     CX = row
  1966. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1967.       their parameters do not change (see #03474 at AX=0000h)
  1968.     This call is ignored in text modes
  1969. SeeAlso: AX=0006h,AX=001Dh,AX=004Dh,AX=0090h
  1970. --------V-620090-----------------------------
  1971. INT 62 u - FGDRIVER v4.02 - "FG_POINTX" - DISPLAY A PIXEL IN XOR MODE
  1972.     AX = 0090h
  1973.     BX = column
  1974.     CX = row
  1975. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1976.       their parameters do not change (see #03474 at AX=0000h)
  1977.     This call is ignored in text modes
  1978. SeeAlso: AX=004Dh,AX=008Fh
  1979. --------V-620091-----------------------------
  1980. INT 62 u - FGDRIVER v4.02 - "FG_POLYEDGE" - SPECIFY INCLUSION OF FINAL PIXELS
  1981.     AX = 0091h
  1982.     BX = edge flag
  1983.         0000h include right- and bottom-edge pixels when drawing polygons
  1984.           with FG_POLYFILL
  1985.         0001h (default) exclue right- and bottom-edge pixels
  1986. SeeAlso: AX=0092h
  1987. --------V-620092-----------------------------
  1988. INT 62 u - FGDRIVER v4.02 - "FG_POLYFILL" - DRAW A FILLED CONVEX POLYGON
  1989.     AX = 0092h
  1990.     CX = number of vertices
  1991.     ES:BX -> variable pointer record (see #03496)
  1992. Notes:    the FGDRIVER functions are rearranged with each major release, but
  1993.       their parameters do not change (see #03474 at AX=0000h)
  1994.     The vertex array consists of pairs of words specifying the X and Y
  1995.       coordinates of each vertex; the work array is used internally and
  1996.       must contain at least four times as many bytes as the polygon is
  1997.       high in pixels
  1998.     This function is ignored in text modes
  1999.     If the polygon is non-convex, only a portion of it may be filled
  2000. SeeAlso: AX=000Eh,AX=0027h,AX=0091h,AX=0093h,AX=0094h,AX=0095h
  2001.  
  2002. Format of FGDRIVER POLYFILL variable pointer record:
  2003. Offset    Size    Description    (Table 03496)
  2004.  00h    WORD    segment of vertex array (see #03498)
  2005.  02h    WORD    offset of vertex array
  2006.  04h    WORD    segment of work array
  2007.  06h    WORD    offset of work array
  2008. SeeAlso: #03497
  2009. --------V-620093-----------------------------
  2010. INT 62 u - FGDRIVER v4.02 - "FG_POLYGON" - DRAW AN UNFILLED POLYGON
  2011.     AX = 0093h
  2012.     CX = number of vertices in polygon
  2013.     ES:BX -> variable pointer record (see #03497)
  2014. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2015.       their parameters do not change (see #03474 at AX=0000h)
  2016.     This call is ignored in text modes
  2017. SeeAlso: AX=0091h,AX=0092h,AX=0094h,AX=0095h
  2018.  
  2019. Format of FGDRIVER POLYGON variable pointer record:
  2020. Offset    Size    Description    (Table 03497)
  2021.  00h    WORD    segment of WORD array containing vertex columns
  2022.  02h    WORD    offset of WORD array containing vertex columns
  2023.  04h    WORD    segment of WORD array containing vertex rows
  2024.  06h    WORD    offset of WORD array containing vertex rows
  2025. SeeAlso: #03496
  2026. --------V-620094-----------------------------
  2027. INT 62 u - FGDRIVER v4.02 - "FG_POLYLINE" - DRAW AN UNFILLED POLYGON
  2028.     AX = 0094h
  2029.     CX = number of vertices in polygon
  2030.     ES:BX -> vertex array (see #03498)
  2031. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2032.       their parameters do not change (see #03474 at AX=0000h)
  2033.     This function is equivalent to "FG_POLYGON", but uses only a single
  2034.       array to define the vertices
  2035.     This call is ignored in text modes
  2036. SeeAlso: AX=008Fh,AX=0092h,AX=0093h,AX=0095h
  2037.  
  2038. Format of FGDRIVER POLYFILL/POLYLINE vertex array element:
  2039. Offset    Size    Description    (Table 03498)
  2040.  00h    WORD    column
  2041.  02h    WORD    row
  2042. SeeAlso: #03497
  2043. --------V-620095-----------------------------
  2044. INT 62 u - FGDRIVER v4.02 - "FG_POLYOFF" - DEFINE POLYGON DRAWING OFFSET
  2045.     AX = 0095h
  2046.     BX = horizontal offset (default 0)
  2047.     CX = vertical offset (default 0)
  2048. Desc:    define the offsets applied to all vertices of polygons drawn with
  2049.       "FG_POLYFILL" or "FG_POLYLINE"
  2050. Note:    the FGDRIVER functions are rearranged with each major release, but
  2051.       their parameters do not change (see #03474 at AX=0000h)
  2052. SeeAlso: AX=0092h,AX=0094h
  2053. --------V-620096-----------------------------
  2054. INT 62 u - FGDRIVER v4.02 - "FG_PRINT" - DISPLAY STRING OF HARDWARE CHARACTERS
  2055.     AX = 0096h
  2056.     CX = length of string
  2057.     ES:BX -> string to display
  2058. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2059.       their parameters do not change (see #03474 at AX=0000h)
  2060.     The string is displayed in the current color, and the graphics cursor
  2061.       is updated to be just to the right of the last displayed character
  2062.     This function is ignored in text modes
  2063. SeeAlso: AX=000Ch,AX=0037h,AX=0065h,AX=0097h
  2064. --------V-620097-----------------------------
  2065. INT 62 u - FGDRIVER v4.02 - "FG_PRINTC" - DISPLAY STRING OF HW CHARS (CLIPPED)
  2066.     AX = 0097h
  2067.     CX = length of string
  2068.     ES:BX -> string to display
  2069. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2070.       their parameters do not change (see #03474 at AX=0000h)
  2071.     The string is displayed in the current color, and the graphics cursor
  2072.       is updated to be just to the right of the last displayed character;
  2073.       only the portion of the string that lies within the current clipping
  2074.       area is displayed
  2075.     This function is ignored in text modes
  2076. SeeAlso: AX=0096h
  2077. --------V-620098-----------------------------
  2078. INT 62 u - FGDRIVER v4.02 - "FG_PUTBLOCK" - RESTORE RECTANGLE OF DISPLAY
  2079.     AX = 0098h
  2080.     ES:BX -> buffer containing previously-saved image
  2081.     CX = left edge
  2082.     DX = right edge
  2083.     SI = top edge
  2084.     DI = bottom edge
  2085. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2086.       their parameters do not change (see #03474 at AX=0000h)
  2087.     In text modes, coordinates are character positions; in graphics modes,
  2088.       they are defined in screen space, and the left and right edges are
  2089.       adjusted to a byte boundary if necessary
  2090. SeeAlso: AX=003Ch,AX=0099h
  2091. --------V-620099-----------------------------
  2092. INT 62 u - FGDRIVER v4.02 - "FG_PUTIMAGE" - DISPLAY MODE-SPECIFIC BITMAP IMAGE
  2093.     AX = 0099h
  2094.     ES:BX -> buffer containing mode-specific bitmap
  2095.     CX = width in bytes
  2096.     DX = height in pixel rows
  2097. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2098.       their parameters do not change (see #03474 at AX=0000h)
  2099.     The bitmap is displayed with its lower left corner at the graphics
  2100.       cursor position; color 0 is NOT treated as transparent
  2101. SeeAlso: AX=0011h,AX=0024h,AX=0036h,AX=0044h,AX=0098h
  2102. --------V-62009A-----------------------------
  2103. INT 62 u - FGDRIVER v4.02 - "FG_QUIET" - STOP CONTINUOUS SYNCHRONOUS SOUND
  2104.     AX = 009Ah
  2105. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2106.       their parameters do not change (see #03474 at AX=0000h)
  2107.     This call has no effect if there is no continuous sound playing
  2108. SeeAlso: AX=0059h,AX=0080h,AX=00BDh,AX=00DCh
  2109. --------V-62009B-----------------------------
  2110. INT 62 u - FGDRIVER v4.02 - "FG_RECT" - DRAW UNFILLED RECTANGLE IN SCREEN SPACE
  2111.     AX = 009Bh
  2112.     BX = left edge column
  2113.     CX = right edge column
  2114.     DX = top edge row
  2115.     SI = bottom edge row
  2116. Note:    the FGDRIVER functions are rearranged with each major release, but
  2117.       their parameters do not change (see #03474 at AX=0000h)
  2118. SeeAlso: AX=0006h,AX=0012h,AX=0023h,AX=003Ch
  2119. --------V-62009C-----------------------------
  2120. INT 62 u - FGDRIVER v4.02 - "FG_RESET" - ERASE SCREEN AND RESTORE SCREEN ATTR
  2121.     AX = 009Ch
  2122. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2123.       their parameters do not change (see #03474 at AX=0000h)
  2124.     This call is ignored in graphics modes
  2125.     The screen attributes are only restored if ANSI.SYS is loaded
  2126. SeeAlso: AX=0028h,AX=00B0h
  2127. --------V-62009D-----------------------------
  2128. INT 62 u - FGDRIVER v4.02 - "FG_RESIZE" - SET GRAPHICS MODE VIDEO PAGE SIZE
  2129.     AX = 009Dh
  2130.     BX = new page width in pixels
  2131.     CX = new page height in pixels
  2132. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2133.       their parameters do not change (see #03474 at AX=0000h)
  2134.     The visible page must be set to 0000h before making this call
  2135.     The mouse, joysticks, expanded memory, and extended memory must be
  2136.       reinitialized after this call
  2137. SeeAlso: AX=0084h,AX=00ACh
  2138. --------V-62009E-----------------------------
  2139. INT 62 u - FGDRIVER v4.02 - "FG_RESTORE" - COPY REGION FROM HIDDEN TO VIS PAGE
  2140.     AX = 009Eh
  2141.     BX = left edge column
  2142.     CX = right edge column
  2143.     DX = top edge row
  2144.     SI = bottom edge row
  2145. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2146.       their parameters do not change (see #03474 at AX=0000h)
  2147.     The left and right edges are adjusted to byte boundaries if necessary
  2148. SeeAlso: AX=00A2h,AX=00C6h
  2149. --------V-62009F-----------------------------
  2150. INT 62 u - FGDRIVER v4.02 - "FG_RESUME" - RESTART ASYNCHRONOUS SOUND
  2151.     AX = 009Fh
  2152. Note:    the FGDRIVER functions are rearranged with each major release, but
  2153.       their parameters do not change (see #03474 at AX=0000h)
  2154. SeeAlso: AX=00BDh,AX=00C0h
  2155. --------V-6200A0-----------------------------
  2156. INT 62 u - FGDRIVER v4.02 - "FG_REVIMAGE" - DISPLAY REVERSED IMAGE (BITMAP)
  2157.     AX = 00A0h
  2158.     ES:BX -> mode-specific bitmap
  2159.     CX = width of bitmap in bytes
  2160.     DX = height of bitmap in pixel rows
  2161. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2162.       their parameters do not change (see #03474 at AX=0000h)
  2163.     This call is ignored in text modes
  2164.     The image is drawn with its lower left corner at the current graphics
  2165.       cursor position
  2166. SeeAlso: AX=0011h,AX=0024h,AX=0036h,AX=0044h,AX=00A1h,AX=00A9h,AX=00B9h
  2167. --------V-6200A1-----------------------------
  2168. INT 62 u - FGDRIVER v4.02 - "FG_REVMASK" - DISPLAY REVERSED IMAGE (MASKING MAP)
  2169.     AX = 00A1h
  2170.     ES:BX -> array containing image stored as a masking map (see #03475)
  2171.     CX = number of pixel runs in masking map
  2172.     DX = width of masking map in pixels
  2173. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2174.       their parameters do not change (see #03474 at AX=0000h)
  2175.     This call is ignored in text modes and in native EGA and VGA graphics
  2176.       modes
  2177.     The image is drawn with its lower left corner at the current graphics
  2178.       cursor position
  2179. SeeAlso: AX=0010h,AX=001Fh,AX=0034h,AX=00A0h,AX=00A9h,AX=00C5h
  2180. --------V-6200A2-----------------------------
  2181. INT 62 u - FGDRIVER v4.02 - "FG_SAVE" - COPY REGION FROM VISIBLE TO HIDDEN PAGE
  2182.     AX = 00A2h
  2183.     BX = left edge column
  2184.     CX = right edge column
  2185.     DX = top edge row
  2186.     SI = bottom edge row
  2187. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2188.       their parameters do not change (see #03474 at AX=0000h)
  2189.     The left and right edges are adjusted to byte boundaries if necessary
  2190. SeeAlso: AX=009Eh,AX=00C6h
  2191. --------V-6200A3-----------------------------
  2192. INT 62 u - FGDRIVER v4.02 - "FG_SCALE" - SCALE BITMAP
  2193.     AX = 00A3h
  2194.     ES:BX -> variable pointer record (see #03499)
  2195.     CX = width of source bitmap in pixels (0 < width <= 1024)
  2196.     DX = height of source bitmap in pixels (0 < height <= 1024)
  2197.     SI = desired width of scaled bitmap (0 < width <= 1024)
  2198.     DI = desired height of scaled bitmap (0 < height <= 1024)
  2199. Return: nothing
  2200. SeeAlso: AX=00B7h
  2201.  
  2202. Format of FGDRIVER SCALE variable pointer record:
  2203. Offset    Size    Description    (Table 03499)
  2204.  00h    WORD    segment of source bitmap (one pixel per byte)
  2205.  02h    WORD    offset of source bitmap
  2206.  04h    WORD    segment of buffer for resulting scaled bitmap
  2207.  06h    WORD    offset of buffer for resulting scaled bitmap
  2208. --------V-6200A4-----------------------------
  2209. INT 62 u - FGDRIVER v4.02 - "FG_SCRLOCK" - GET STATE OF SCROLL LOCK KEY
  2210.     AX = 00A4h
  2211. Return: AX = ScrollLock state (0000h off, 0001h on)
  2212. Program: FGDRIVER is the external video driver for the shareware
  2213.       Fastgraph/Light by Ted Gruber Software
  2214. Note:    the FGDRIVER functions are rearranged with each major release, but
  2215.       their parameters do not change (see #03474 at AX=0000h)
  2216. SeeAlso: AX=000Ah,AX=0082h,AX=00A8h,AX=00B1h
  2217. --------V-6200A5-----------------------------
  2218. INT 62 u - FGDRIVER v4.02 - "FG_SCROLL" - VERTICALLY SCROLL SCREEN REGION
  2219.     AX = 00A5h
  2220.     BX = left edge column
  2221.     CX = right edge column
  2222.     DX = top edge row
  2223.     SI = bottom edge row
  2224.     DI = number of pixels by which to scroll (positive scrolls up,
  2225.           negative scrolls down)
  2226.     ES = type of scroll
  2227.         0000h circular (rows scrolled off are copied to vacated rows)
  2228.         else vacated rows are filled with the current color
  2229. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2230.       their parameters do not change (see #03474 at AX=0000h)
  2231.     In graphics modes, the left and right edges are adjusted to byte
  2232.       boundaries if necessary
  2233.     Circular scrolling uses part of the hidden page as a workspace
  2234. SeeAlso: AX=0088h,AX=00B2h
  2235. --------V-6200A6-----------------------------
  2236. INT 62 u - FGDRIVER v4.02 - "FG_SETATTR" - SET TEXT-MODE CHARACTER ATTRIBUTE
  2237.     AX = 00A6h
  2238.     BX = foreground
  2239.     CX = background
  2240.     DX = blink (0000h nonblinking, 0001h blink)
  2241. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2242.       their parameters do not change (see #03474 at AX=0000h)
  2243.     This call is ignored in graphics modes
  2244. SeeAlso: AX=000Bh,AX=003Ah,AX=0048h
  2245. --------V-6200A7-----------------------------
  2246. INT 62 u - FGDRIVER v4.02 - "FG_SETBANKS" - SET SVGA READ AND WRITE BANKS
  2247.     AX = 00A7h
  2248.     BX = memory bank from which to read (FFFFh leave unchanged)
  2249.     CX = memory bank to which to write (FFFFh leave unchanged)
  2250. Note:    the FGDRIVER functions are rearranged with each major release, but
  2251.       their parameters do not change (see #03474 at AX=0000h)
  2252. SeeAlso: AX=003Bh
  2253. --------V-6200A8-----------------------------
  2254. INT 62 u - FGDRIVER v4.02 - "FG_SETCAPS" - SET STATE OF CAPSLOCK KEY
  2255.     AX = 00A8h
  2256.     BX = new state (0000h off, 0001h on)
  2257. Note:    the FGDRIVER functions are rearranged with each major release, but
  2258.       their parameters do not change (see #03474 at AX=0000h)
  2259. SeeAlso: AX=000Ah,AX=0082h,AX=00A4h,AX=00B1h
  2260. --------V-6200A9-----------------------------
  2261. INT 62 u - FGDRIVER v4.02 - "FG_SETCLIP" - SET CLIPPING REGION
  2262.     AX = 00A9h
  2263.     BX = left edge of clipping region
  2264.     CX = right edge of clipping region
  2265.     DX = top edge of clipping region
  2266.     SI = bottom edge of clipping region
  2267. Note:    the FGDRIVER functions are rearranged with each major release, but
  2268.       their parameters do not change (see #03474 at AX=0000h)
  2269. SeeAlso: AX=0010h,AX=001Fh,AX=0034h,AX=003Eh,AX=00A1h,AX=00C5h
  2270. --------V-6200AA-----------------------------
  2271. INT 62 u - FGDRIVER v4.02 - "FG_SETCOLOR" - SET CURRENT COLOR
  2272.     AX = 00AAh
  2273.     BX = new color index (or text attribute in text modes)
  2274. Note:    the FGDRIVER functions are rearranged with each major release, but
  2275.       their parameters do not change (see #03474 at AX=0000h)
  2276. SeeAlso: AX=0018h,AX=0040h,AX=0045h
  2277. --------V-6200AB-----------------------------
  2278. INT 62 u - FGDRIVER v4.02 - "FG_SETDACS" - SET VIDEO DAC CONTENTS
  2279.     AX = 00ABh
  2280.     CX = number of DAC registers to set (0001h to 0100h)
  2281.     DX = starting DAC register number (0000h to 00FFh)
  2282.     ES:BX -> buffer containing DAC red/green/blue triples
  2283. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2284.       their parameters do not change (see #03474 at AX=0000h)
  2285.     The register number wraps back to zero after reaching FFh
  2286.     This call has no effect in text modes or graphics modes below 11h
  2287. SeeAlso: AX=0041h,AX=004Eh,AX=0086h,INT 10/AX=1012h
  2288. --------V-6200AC-----------------------------
  2289. INT 62 u - FGDRIVER v4.02 - "FG_SETENTRY" - SET TYPE AND ADDRESS OF VIDEO PAGE
  2290.     AX = 00ACh
  2291.     BX = page number (00h-3Fh)
  2292.     CX = page address
  2293.     DX = page type (see #03484 at AX=0042h)
  2294. Note:    the FGDRIVER functions are rearranged with each major release, but
  2295.       their parameters do not change (see #03474 at AX=0000h)
  2296. SeeAlso: AX=0038h,AX=0042h,AX=00B0h
  2297. --------V-6200AD-----------------------------
  2298. INT 62 u - FGDRIVER v4.02 - "FG_SETFUNC" - SET LOGICAL OPERATION FOR VIDEO OPS
  2299.     AX = 00ADh
  2300.     BX = operation
  2301.         0000h replacement
  2302.         0001h AND
  2303.         0002h OR
  2304.         0003h XOR
  2305. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2306.       their parameters do not change (see #03474 at AX=0000h)
  2307.     This function is only available in native EGA/VGA graphics modes
  2308.       (0Dh to 12h)
  2309. SeeAlso: AX=001Eh,AX=008Fh
  2310. --------V-6200AE-----------------------------
  2311. INT 62 u - FGDRIVER v4.02 - "FG_SETHPAGE" - SET HIDDEN VIDEO PAGE
  2312.     AX = 00AEh
  2313.     BX = new hidden page (0000h to 003Fh)
  2314. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2315.       their parameters do not change (see #03474 at AX=0000h)
  2316.     The specified page must be a physical page or a virtual page
  2317. SeeAlso: AX=0043h,AX=00B2h,AX=00B6h
  2318. --------V-6200AF-----------------------------
  2319. INT 62 u - FGDRIVER v4.02 - "FG_SETLINES" - SET TEXT ROWS ON SCREEN
  2320.     AX = 00AFh
  2321.     BX = new screen size (25, 43, 50)
  2322. Note:    the FGDRIVER functions are rearranged with each major release, but
  2323.       their parameters do not change (see #03474 at AX=0000h)
  2324. SeeAlso: AX=0047h
  2325. --------V-6200B0-----------------------------
  2326. INT 62 u - FGDRIVER v4.02 - "FG_SETMODE" - SELECT VIDEO MODE AND INITIALIZE
  2327.     AX = 00B0h
  2328.     BX = new video mode or FFFFh for current mode (see #03500)
  2329.     ES:DX -> WORD shareware splash screen flag
  2330. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2331.       their parameters do not change (see #03474 at AX=0000h)
  2332.     This call resets the active video page to page 0000h, the clipping
  2333.       region to the entire screen, text rows to 25, etc.
  2334.     in the shareware version, FGDRIVER sets the word pointed at by ES:DX
  2335.       to 9090h after it shows the shareware announcement to the user
  2336. SeeAlso: AX=004Bh,INT 10/AH=00h
  2337.  
  2338. (Table 03500)
  2339. Values for FGDRIVER video mode:
  2340.  00h-07h standard BIOS modes
  2341.  09h    PCjr/Tandy1000 320x200x16
  2342.  0Bh    Hercules graphics 720x348
  2343.  0Ch    Hercules graphics 320x200
  2344.  0Dh-13h standard BIOS modes
  2345.  14h    VGA graphics 320x200x256
  2346.  15h    VGA graphics 320x400x256
  2347.  16h    VGA graphics 320x240x256
  2348.  17h    VGA graphics 320x480x256
  2349.  18h    SVGA graphics 640x400x256
  2350.  19h    SVGA graphics 640x480x256
  2351.  1Ah    SVGA graphics 800x600x256
  2352.  1Bh    SVGA graphics 1024x768x256
  2353.  1Ch    SVGA graphics 800x600x16
  2354.  1Dh    SVGA graphics 1024x768x16
  2355. --------V-6200B1-----------------------------
  2356. INT 62 u - FGDRIVER v4.02 - "FG_SETNUM" - SET STATE OF NUMLOCK KEY
  2357.     AX = 00B1h
  2358.     BX = new state (0000h off, 0001h on)
  2359. Note:    the FGDRIVER functions are rearranged with each major release, but
  2360.       their parameters do not change (see #03474 at AX=0000h)
  2361. SeeAlso: AX=000Ah,AX=0082h,AX=00A4h,AX=00A8h
  2362. --------V-6200B2-----------------------------
  2363. INT 62 u - FGDRIVER v4.02 - "FG_SETPAGE" - SET ACTIVE VIDEO PAGE
  2364.     AX = 00B2h
  2365.     BX = new video page (0000h to 003Fh)
  2366. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2367.       their parameters do not change (see #03474 at AX=0000h)
  2368.     The specified page must be a physical or virtual page
  2369. SeeAlso: AX=0039h,AX=0042h,AX=0043h,AX=0050h,AX=0088h
  2370. --------V-6200B3-----------------------------
  2371. INT 62 u - FGDRIVER v4.02 - "FG_SETRGB" - SET VIDEO DAC REGISTER CONTENTS
  2372.     AX = 00B3h
  2373.     BX = palette or DAC register number
  2374.     CX = red color component
  2375.     DX = green component
  2376.     SI = blue component
  2377. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2378.       their parameters do not change (see #03474 at AX=0000h)
  2379.     The register number may be negative for Tandy, PCjr, and 200-line
  2380.       EGA graphics modes to specify an intense color
  2381.     This call has no effect in text, CGA graphics, and Hercules graphics
  2382.       modes
  2383. SeeAlso: AX=004Eh
  2384. --------V-6200B4-----------------------------
  2385. INT 62 u - FGDRIVER v4.02 - UNUSED
  2386.     AX = 00B4h
  2387. Return: AX = 0000h
  2388. Note:    the FGDRIVER functions are rearranged with each major release, but
  2389.       their parameters do not change (see #03474 at AX=0000h)
  2390. --------V-6200B5-----------------------------
  2391. INT 62 u - FGDRIVER v4.02 - "FG_SETVIEW" - DEFINE VIEWPORT
  2392.     AX = 00B5h
  2393.     ES:BX -> variable record (see #03501)
  2394.     CX = viewport's top edge in screen space
  2395.     DX = viewport's bottom edge in screen space
  2396. Return: nothing
  2397. Note:    the FGDRIVER functions are rearranged with each major release, but
  2398.       their parameters do not change (see #03474)
  2399. SeeAlso: AX=004Fh
  2400.  
  2401. Format of FGDRIVER SETVIEW variable record:
  2402. Offset    Size    Description    (Table 03501)
  2403.  00h    WORD    viewport's left edge in viewport units
  2404.  02h    WORD    viewport's right edge in viewport units
  2405.  04h    WORD    viewport's top edge in viewport units
  2406.  06h    WORD    viewport's bottom edge in viewport units
  2407.  08h    WORD    viewport's left edge in screen space
  2408.  0Ah    WORD    viewport's right edge in screen space
  2409. --------V-6200B6-----------------------------
  2410. INT 62 u - FGDRIVER v4.02 - "FG_SETVPAGE" - SET VISIBLE VIDEO PAGE
  2411.     AX = 00B6h
  2412.     BX = new video page (0000h to 003Fh)
  2413. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2414.       their parameters do not change (see #03474 at AX=0000h)
  2415.     The specified page must be a physical or virtual page
  2416. SeeAlso: AX=0043h,AX=00AEh,AX=00B2h
  2417. --------V-6200B7-----------------------------
  2418. INT 62 u - FGDRIVER v4.02 - "FG_SHEAR" - SHEAR UNPACKED BITMAP
  2419.     AX = 00B7h
  2420.     ES:BX -> variable pointer record (see #03502)
  2421.     CX = bitmap width (0 < width <= 1024)
  2422.     DX = bitmap height (0 < height <= 1024)
  2423.     SI = size of resulting image (width for horiz. shear, height for vert.)
  2424.     DI = shear type
  2425.         0000h horizontal shear to left
  2426.         0001h horizontal shear to right
  2427.         0002h vertical shear to left (left edge stretched up)
  2428.         0003h vertical shear to right (right edge stretched up)
  2429. Return: nothing
  2430. Note:    the FGDRIVER functions are rearranged with each major release, but
  2431.       their parameters do not change (see #03474)
  2432. SeeAlso: AX=00A3h
  2433.  
  2434. Format of FGDRIVER SHEAR variable pointer record:
  2435. Offset    Size    Description    (Table 03502)
  2436.  00h    WORD    segment of source bitmap
  2437.  02h    WORD    offset of source bitmap
  2438.  04h    WORD    segment of buffer for resulting bitmap
  2439.  06h    WORD    offset of buffer for resulting bitmap
  2440. --------V-6200B8-----------------------------
  2441. INT 62 u - FGDRIVER v4.02 - "FG_SHOWFLIC" - DISPLAY IMAGE FROM FLI/FLC FILE
  2442.     AX = 00B8h
  2443.     ES:BX -> ASCIZ filename for FLI/FLC file
  2444.     CX = number of times to display image file (0000h = continuously)
  2445.     DX = control flags (see #03479 at AX=0031h)
  2446. Return: AX = status
  2447.         0000h successful
  2448.         0001h file not found
  2449.         0002h not a valid FLI/FLC file
  2450. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2451.       their parameters do not change (see #03474)
  2452.     the FLI/FLC display may be stopped by the user by pressing Esc
  2453. SeeAlso: AX=0030h,AX=0031h,AX=00B9h
  2454. --------V-6200B9-----------------------------
  2455. INT 62 u - FGDRIVER v4.02 - "FG_SHOWPCX" - DISPLAY IMAGE FROM PCX FILE
  2456.     AX = 00B9h
  2457.     ES:BX -> ASCIZ filename of PCX image
  2458.     CX = flags (see #03503)
  2459. Return: AX = status
  2460.         0000h success
  2461.         0001h file not found
  2462.         0002h not a PCX file
  2463. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2464.       their parameters do not change (see #03474 at AX=0000h)
  2465.     This function is ignored in text modes and Hercules low-res graphics
  2466. SeeAlso: AX=005Bh,AX=0060h"1.10",AX=006Ch,AX=006Dh,AX=006Eh,AX=00B8h,AX=00BAh
  2467. SeeAlso: AX=00BBh
  2468.  
  2469. Bitfields for FGDRIVER flags:
  2470. Bit(s)    Description    (Table 03503)
  2471.  0    use current palette rather than PCX file's palette
  2472.  1    display image at cursor position instead of position in PCX header
  2473.  2-15    reserved
  2474. --------V-6200BA-----------------------------
  2475. INT 62 u - FGDRIVER v4.02 - "FG_SHOWPPR" - DISPLAY IMAGE FROM PPR FILE
  2476.     AX = 00BAh
  2477.     ES:BX -> ASCIZ filename of packed pixel run image
  2478.     CX = width in pixels (nonzero)
  2479. Return: AX = status
  2480.         0000h successful
  2481.         0001h file not found
  2482. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2483.       their parameters do not change (see #03474 at AX=0000h)
  2484.     The image is displayed with its lower left corner at the current
  2485.       graphics cursor position
  2486.     This function is ignored in text modes and 256-color graphics modes
  2487. SeeAlso: AX=005Bh,AX=006Ch,AX=006Dh,AX=006Eh,AX=00B9h,AX=00BBh
  2488. --------V-6200BB-----------------------------
  2489. INT 62 u - FGDRIVER v4.02 - "FG_SHOWSPR" - DISPLAY IMAGE FROM SPR FILE
  2490.     AX = 00BBh
  2491.     ES:BX -> ASCIZ filename of standard pixel run image
  2492.     CX = width in pixels (nonzero)
  2493. Return: AX = status
  2494.         0000h successful
  2495.         0001h file not found
  2496. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2497.       their parameters do not change (see #03474 at AX=0000h)
  2498.     The image is displayed with its lower left corner at the current
  2499.       graphics cursor position
  2500.     This function is ignored in text modes
  2501. SeeAlso: AX=005Bh,AX=006Ch,AX=006Dh,AX=006Eh,AX=00B9h,AX=00BAh
  2502. --------V-6200BC-----------------------------
  2503. INT 62 u - FGDRIVER v4.02 - "FG_SOUND" - MAKE SOUND FOR SPECIFIED DURATION
  2504.     AX = 00BCh
  2505.     BX = frequency in Hertz (18-32767)
  2506.     CX = duration in clock ticks (0000h or negative for continuous sound)
  2507. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2508.       their parameters do not change (see #03474 at AX=0000h)
  2509.     This call is ignored if asynchronous sound (AX=00A5h,AX=00A8h,
  2510.       AX=00AAh) is already in progress
  2511. SeeAlso: AX=0059h,AX=0080h,AX=00BDh,AX=00C0h,AX=00DBh
  2512. --------V-6200BD-----------------------------
  2513. INT 62 u - FGDRIVER v4.02 - "FG_SOUNDS" - PLAY SOUNDS IN BACKGROUND
  2514.     AX = 00BDh
  2515.     CX = number of times to cycle through sound list
  2516.     ES:BX -> sounds array (see #03504)
  2517. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2518.       their parameters do not change (see #03474 at AX=0000h)
  2519.     This call is ignored if asynchronous sound (AX=00A5h,AX=00A8h,
  2520.       AX=00AAh) is already in progress
  2521. SeeAlso: AX=0059h,AX=0081h,AX=00BCh,AX=00C0h,AX=00DCh
  2522.  
  2523. Format of FGDRIVER sounds array element:
  2524. Offset    Size    Description    (Table 03504)
  2525.  00h    WORD    frequency of sound in Hertz (0000h ends array)
  2526.  02h    WORD    duration of sound in clock ticks
  2527. --------V-6200BE-----------------------------
  2528. INT 62 u - FGDRIVER v4.02 - "FG_SPLIT" - ENABLE/DISABLE SPLIT SCREEN ENVIRONMNT
  2529.     AX = 00BEh
  2530.     BX = beginning row for bottom half of split-screen
  2531. Note:    the FGDRIVER functions are rearranged with each major release, but
  2532.       their parameters do not change (see #03474)
  2533. --------V-6200BF-----------------------------
  2534. INT 62 u - FGDRIVER v4.02 - "FG_STALL" - PAUSE FOR SPECIFIED DURATION
  2535.     AX = 00BFh
  2536.     BX = duration in processor-dependent delay units (see AX=0070h)
  2537. Return: after delay elapses
  2538. Note:    the FGDRIVER functions are rearranged with each major release, but
  2539.       their parameters do not change (see #03474 at AX=0000h)
  2540. SeeAlso: AX=0070h,INT 2F/AX=1224h
  2541. --------V-6200C0-----------------------------
  2542. INT 62 u - FGDRIVER v4.02 - "FG_SUSPEND" - TEMPORARILY STOP ASYNCHRONOUS SOUND
  2543.     AX = 00C0h
  2544. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2545.       their parameters do not change (see #03474 at AX=0000h)
  2546.     This call has no effect if there is no asynchronous sound in progress
  2547.     The program must not exit while sound is suspended
  2548. SeeAlso: AX=0059h,AX=0080h,AX=00BDh,AX=00C0h,AX=00DBh
  2549. --------V-6200C1-----------------------------
  2550. INT 62 u - FGDRIVER v4.02 - "FG_SVGAINIT" - INITIALIZE FASTGRAPH SVGA KERNEL
  2551.     AX = 00C1h
  2552.     BX = method (see #03505)
  2553. Return: AX = status
  2554.         0000h no VESA BIOS or supported SVGA chipset
  2555.         0001h using VESA BIOS
  2556.         0002h-0016h specific chipset being used (same as "method" below)
  2557. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2558.       their parameters do not change (see #03474 at AX=0000h)
  2559.     This function must be called before attempting to set SVGA graphics
  2560.       modes (18h to 1Dh) or using "FG_BESTMODE", "FG_TESTMODE", or
  2561.       "FG_MEMORY"
  2562. SeeAlso: AX=0025h,AX=00C2h,AX=00C3h
  2563.  
  2564. (Table 03505)
  2565. Values for FGDRIVER SVGA method:
  2566.  0000h    autodetect, give chipset-specific code priority over VESA
  2567.  0001h    autodetect, give VESA priority over chipset-specific code
  2568.  0002h    Ahead type "A"
  2569.  0003h    Ahead type "B"
  2570.  0004h    ATI 18800
  2571.  0005h    ATI 18800-1
  2572.  0006h    ATI 28800
  2573.  0007h    Chips & Technologies 82c451/455/456
  2574.  0008h    C&T 82c452
  2575.  0009h    C&T 82c453
  2576.  000Ah    Genoa 6000 series
  2577.  000Bh    Oak OTI-067
  2578.  000Ch    Paradise PVGA1a
  2579.  000Dh    Paradise WD90C00/WD90C10
  2580.  000Eh    Paradise WD90C11/WD90C30/WD90C31
  2581.  000Fh    Trident 8800
  2582.  0010h    Trident 8900
  2583.  0011h    Tseng ET3000
  2584.  0012h    Tseng ET4000
  2585.  0013h    Video7
  2586.  0014h    Cirrus Logic 5400 series
  2587.  0015h    S3
  2588.  0016h    Trident 8900B/8900C/9000
  2589. --------V-6200C2-----------------------------
  2590. INT 62 u - FGDRIVER v4.02 - "FG_SVGASTAT" - GET SVGA CHIPSET INFORMATION
  2591.     AX = 00C2h
  2592. Return: AX = chipset information (see #03506)
  2593. Note:    the FGDRIVER functions are rearranged with each major release, but
  2594.       their parameters do not change (see #03474 at AX=0000h)
  2595. SeeAlso: AX=0025h,AX=00C1h,AX=00C3h
  2596.  
  2597. Bitfields for FGDRIVER chipset information:
  2598. Bit(s)    Description    (Table 03506)
  2599.  0    SVGA kernel initialized
  2600.  1    VESA support enabled
  2601.  2    extended video pages available in modes 13-23
  2602.  3    SVGA chipset has separate read and write banks
  2603.  4-15    reserved (0)
  2604. --------V-6200C3-----------------------------
  2605. INT 62 u - FGDRIVER v4.02 - "FG_SVGAVER" - GET FASTGRAPH SVGA KERNEL VERSION
  2606.     AX = 00C3h
  2607.     ES:BX -> variable pointer record (see #03507)
  2608. Note:    the FGDRIVER functions are rearranged with each major release, but
  2609.       their parameters do not change (see #03474 at AX=0000h)
  2610. SeeAlso: AX=00C1h,AX=00C2h
  2611.  
  2612. Format of FGDRIVER variable pointer record:
  2613. Offset    Size    Description    (Table 03507)
  2614.  00h    WORD    segment of WORD buffer for major version
  2615.  02h    WORD    offset of WORD buffer for major version
  2616.  04h    WORD    segment of WORD buffer for minor version (hundredths)
  2617.  06h    WORD    offset of WORD buffer for minor version
  2618. --------V-6200C4-----------------------------
  2619. INT 62 u - FGDRIVER v4.02 - "FG_TCDEFINE" - DEFINE TRANSPARENCY OF COLOR INDEX
  2620.     AX = 00C4h
  2621.     BX = color index
  2622.     CX = transparency (00h opaque, other transparent)
  2623. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2624.       their parameters do not change (see #03474 at AX=0000h)
  2625.     This function is ignored in text modes
  2626. SeeAlso: AX=00C5h,AX=00C6h
  2627. --------V-6200C5-----------------------------
  2628. INT 62 u - FGDRIVER v4.02 - "FG_TCMASK" - SET TRANSPARENT COLORS
  2629.     AX = 00C5h
  2630.     BX = colors to consider transparent (bit 0 = color 0, etc)
  2631. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2632.       their parameters do not change (see #03474 at AX=0000h)
  2633.     This call is ignored in text modes
  2634.     The specified colors are considered transparent by "FG_TCXFER"
  2635. SeeAlso: AX=00C4h,AX=00C6h
  2636. --------V-6200C6-----------------------------
  2637. INT 62 u - FGDRIVER v4.02 - "FG_TCXFER" - COPY REGION EXCLUDING TRANSPARENT
  2638.     AX = 00C6h
  2639.     CX = source video page
  2640.     DX = destination video page
  2641.     ES:BX -> copy record (see #03508)
  2642. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2643.       their parameters do not change (see #03474 at AX=0000h)
  2644.     Pixels which are in any of the colors defined as transparent with
  2645.       "FG_TCMASK" (see AX=00C5h) are left unchanged in the destination
  2646.       region
  2647.     The source and destination regions must not overlap if they are located
  2648.       on the same page
  2649.     This call is ignored in text modes
  2650. SeeAlso: AX=00C4h,AX=00C5h,AX=00CAh
  2651. --------V-6200C7-----------------------------
  2652. INT 62 u - FGDRIVER v4.02 - "FG_TESTMODE" - CHECK IF VIDEO MODE AVAILABLE
  2653.     AX = 00C7h
  2654.     BX = desired video mode (00h-17h, also 18h-1Dh after "FG_SVGAINIT")
  2655.     CX = required number of video pages (ignore memory size if <= 0)
  2656. Return: AX = status
  2657.         0000h mode not available with requested number of pages
  2658.         0001h mode is available
  2659. Note:    the FGDRIVER functions are rearranged with each major release, but
  2660.       their parameters do not change (see #03474 at AX=0000h)
  2661. SeeAlso: AX=0005h,AX=00B0h
  2662. --------V-6200C8-----------------------------
  2663. INT 62 u - FGDRIVER v4.02 - "FG_TEXT" - DISPLAY STRING OF CHARACTERS
  2664.     AX = 00C8h
  2665.     CX = length of string
  2666.     ES:BX -> string
  2667. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2668.       their parameters do not change (see #03474 at AX=0000h)
  2669.     The string is displayed starting at the text cursor position using the
  2670.       current text attribute (text modes) or color index (graphics modes)
  2671.     The text cursor position is updated after this call
  2672. SeeAlso: AX=000Ch,AX=0096h,AX=00C9h
  2673. --------V-6200C9-----------------------------
  2674. INT 62 u - FGDRIVER v4.02 - "FG_TEXTC" - DISPLAY STRING OF CHARACTERS (CLIPPED)
  2675.     AX = 00C9h
  2676.     CX = length of string
  2677.     ES:BX -> string
  2678. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2679.       their parameters do not change (see #03474)
  2680.     The string is displayed starting at the text cursor position using the
  2681.       current text attribute (text modes) or color index (graphics modes),
  2682.       showing only the portion within the current clipping window
  2683.     The text cursor position is updated after this call
  2684. SeeAlso: AX=00C8h
  2685. --------V-6200CA-----------------------------
  2686. INT 62 u - FGDRIVER v4.02 - "FG_TRANSFER" - COPY REGION
  2687.     AX = 00CAh
  2688.     CX = source video page
  2689.     DX = destination video page
  2690.     ES:BX -> copy record (see #03508)
  2691. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2692.       their parameters do not change (see #03474 at AX=0000h)
  2693.     The source and destination regions must not overlap if they are located
  2694.       on the same page
  2695. SeeAlso: AX=009Eh,AX=00A2h,AX=00A5h,AX=00C6h
  2696.  
  2697. Format of FGDRIVER copy record:
  2698. Offset    Size    Description    (Table 03508)
  2699.  00h    WORD    left edge column of source region
  2700.  02h    WORD    right edge column of source region
  2701.  04h    WORD    top edge row of source region
  2702.  06h    WORD    bottom edge row of source region
  2703.  08h    WORD    left edge of destination
  2704.  0Ah    WORD    bottom edge of destination
  2705. --------V-6200CB-----------------------------
  2706. INT 62 u - FGDRIVER v4.02 - "FG_UNPACK" - EXPAND MODE-SPECIFIC BITMAP
  2707.     AX = 00CBh
  2708.     ES:BX -> variable pointer record (see #03509)
  2709.     CX = size of source bitmap in bytes
  2710. Return: result buffer filled
  2711. Note:    the FGDRIVER functions are rearranged with each major release, but
  2712.       their parameters do not change (see #03474)
  2713. SeeAlso: AX=0083h
  2714.  
  2715. Format of FGDRIVER UNPACK variable pointer record:
  2716. Offset    Size    Description    (Table 03509)
  2717.  00h    WORD    segment of source bitmap
  2718.  02h    WORD    offset of source bitmap
  2719.  04h    WORD    segment of buffer for resulting bitmap
  2720.  06h    WORD    offset of buffer for resulting bitmap
  2721. --------V-6200CC-----------------------------
  2722. INT 62 u - FGDRIVER v4.02 - "FG_VBADDR" - GET ADDRESS OF VIRTUAL BUFFER
  2723.     AX = 00CCh
  2724.     BX = virtual buffer handle (0000h-001Fh)
  2725. Return: DX:AX -> virtual buffer
  2726. Note:    the FGDRIVER functions are rearranged with each major release, but
  2727.       their parameters do not change (see #03474)
  2728. SeeAlso: AX=00CDh,AX=00CEh,AX=00CFh,AX=00D3h
  2729. --------V-6200CD-----------------------------
  2730. INT 62 u - FGDRIVER v4.02 - "FG_VBALLOC" - CREATE VIRTUAL BUFFER
  2731.     AX = 00CDh
  2732.     BX = width of virtual buffer in pixels
  2733.     CX = height in pixels
  2734. Return: AX = handle for virtual buffer, or
  2735.         FFFEh out of memory
  2736.         FFFFh virtual buffer table full
  2737. Note:    the FGDRIVER functions are rearranged with each major release, but
  2738.       their parameters do not change (see #03474)
  2739. SeeAlso: AX=00CCh,AX=00CEh,AX=00D0h,AX=00D1h,AX=00D2h,AX=00D4h
  2740. --------V-6200CE-----------------------------
  2741. INT 62 u - FGDRIVER v4.02 - "FG_VBCLOSE" - CLOSE ACTIVE VIRTUAL BUFFER
  2742.     AX = 00CEh
  2743. Desc:    close the active virtual buffer and direct further graphics to the
  2744.       active video page
  2745. Note:    the FGDRIVER functions are rearranged with each major release, but
  2746.       their parameters do not change (see #03474)
  2747. SeeAlso: AX=00CCh,AX=00D1h,AX=00D4h,AX=00D5h,AX=00D9h
  2748. --------V-6200CF-----------------------------
  2749. INT 62 u - FGDRIVER v4.02 - "FG_VBCOPY" - COPY RECT BETWEEN VIRTUAL BUFFERS
  2750.     AX = 00CFh
  2751.     ES:BX -> variable record (see #03510)
  2752.     CX = handle for source virtual buffer
  2753.     DX = handle for destination virtual buffer
  2754. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2755.       their parameters do not change (see #03474)
  2756.     if the destination buffer is the same as the source buffer, the regions
  2757.       must not overlap
  2758. SeeAlso: AX=00D0h,AX=00D1h,AX=00D4h,AX=00D6h,AX=00D7h
  2759.  
  2760. Format of FGDRIVER VBCOPY variable record:
  2761. Offset    Size    Description    (Table 03510)
  2762.  00h    WORD    source region's left edge
  2763.  02h    WORD    source region's right edge
  2764.  04h    WORD    source region's top edge
  2765.  06h    WORD    source region's bottom edge
  2766.  08h    WORD    X coordinate of destination's upper left corner
  2767.  0Ah    WORD    Y coordinate of destination's upper left corner
  2768. --------V-6200D0-----------------------------
  2769. INT 62 u - FGDRIVER v4.02 - "FG_VBCUT" - COPY RECT FROM VIDEO TO VIRTUAL BUFFER
  2770.     AX = 00D0h
  2771.     BX = source region's left edge
  2772.     CX = source region's right edge
  2773.     DX = source region's top edge
  2774.     SI = source region's bottom edge
  2775.     DI = X coordinate of destination's upper left corner
  2776.     ES = Y coordinate of destination's upper left corner
  2777. Desc:    copy a rectangle from the active video page to the active virtual
  2778.       buffer
  2779. Note:    the FGDRIVER functions are rearranged with each major release, but
  2780.       their parameters do not change (see #03474)
  2781. SeeAlso: AX=00CDh,AX=00CFh,AX=00D4h,AX=00D6h
  2782. --------V-6200D1-----------------------------
  2783. INT 62 u - FGDRIVER v4.02 - "FG_VBDEFINE" - CREATE VIRTUAL BUFFER
  2784.     AX = 00D1h
  2785.     ES:BX -> memory block for virtual buffer
  2786.     CX = buffer width in pixels
  2787.     DX = buffer height in pixels
  2788. Return: AX = virtual buffer handle
  2789.         FFFFh on error
  2790. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2791.       their parameters do not change (see #03474)
  2792.     the application-provided buffer must be large enough to hold CX*DX
  2793.       bytes
  2794. SeeAlso: AX=00CCh,AX=00CDh,AX=00CEh,AX=00D2h,AX=00D4h,AX=00D5h
  2795. --------V-6200D2-----------------------------
  2796. INT 62 u - FGDRIVER v4.02 - "FG_VBFREE" - RELEASE VIRTUAL BUFFER
  2797.     AX = 00D2h
  2798.     BX = virtual buffer handle
  2799. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2800.       their parameters do not change (see #03474)
  2801.     this function should be used only for buffers created with FG_VBALLOC
  2802. SeeAlso: AX=00CDh,AX=00D4h,AX=00D5h
  2803. --------V-6200D3-----------------------------
  2804. INT 62 u - FGDRIVER v4.02 - "FG_VBHANDLE" - GET ACTIVE VIRTUAL BUFFER'S HANDLE
  2805.     AX = 00D3h
  2806. Return: AX = handle for active virtual buffer
  2807. Note:    the FGDRIVER functions are rearranged with each major release, but
  2808.       their parameters do not change (see #03474)
  2809. SeeAlso: AX=00CCh,AX=00D4h
  2810. --------V-6200D4-----------------------------
  2811. INT 62 u - FGDRIVER v4.02 - "FG_VBINIT" - INITIALIZE VIRTUAL BUFFER ENVIRONMENT
  2812.     AX = 00D4h
  2813. Return: nothing
  2814. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2815.       their parameters do not change (see #03474)
  2816.     this function must be called before any other virtual buffer functions
  2817.       are used
  2818. SeeAlso: AX=00CDh,AX=00D5h
  2819. --------V-6200D5-----------------------------
  2820. INT 62 u - FGDRIVER v4.02 - "FG_VBOPEN" - MAKE VIRTUAL BUFFER ACTIVE
  2821.     AX = 00D5h
  2822.     BX = virtual buffer handle
  2823. Return: AX = status
  2824.         0000h successful
  2825.         FFFEh no buffer defined for specified handle
  2826.         FFFFh invalid buffer handle
  2827. Note:    the FGDRIVER functions are rearranged with each major release, but
  2828.       their parameters do not change (see #03474)
  2829. SeeAlso: AX=00CDh,AX=00CEh,AX=00D1h,AX=00D4h,AX=00D9h
  2830. --------V-6200D6-----------------------------
  2831. INT 62 u - FGDRIVER v4.02 - "FG_VBPASTE" - COPY RECT FROM VIRTUAL BUF TO VIDEO
  2832.     AX = 00D6h
  2833.     BX = source region's left edge
  2834.     CX = source region's right edge
  2835.     DX = source region's top edge
  2836.     SI = source region's bottom edge
  2837.     DI = X coordinate of destination's upper left corner
  2838.     ES = Y coordinate of destination's upper left corner
  2839. Desc:    copy a rectangle from the active virtual buffer to the active video
  2840.       page
  2841. Note:    the FGDRIVER functions are rearranged with each major release, but
  2842.       their parameters do not change (see #03474)
  2843. SeeAlso: AX=00CFh,AX=00D0h,AX=00D4h,AX=00D7h
  2844. --------V-6200D7-----------------------------
  2845. INT 62 u - FGDRIVER v4.02 - "FG_VBTCCOPY" - COPY RECTANGLE BETWEEN VIRTUAL BUFS
  2846.     AX = 00D7h
  2847.     ES:BX -> variable record (see #03511)
  2848.     CX = source virtual buffer's handle
  2849.     DX = destination virtual buffer's handle
  2850. Desc:    copy rectangle from one virtual buffer to another with transparent
  2851.       colors
  2852. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2853.       their parameters do not change (see #03474)
  2854.     if the destination buffer is the same as the source buffer, the regions
  2855.       must not overlap
  2856. SeeAlso: AX=00CFh,AX=00D0h,AX=00D6h,AX=00D8h
  2857.  
  2858. Format of FGDRIVER VBTCCOPY variable record:
  2859. Offset    Size    Description    (Table 03511)
  2860.  00h    WORD    source region's left edge
  2861.  02h    WORD    source region's right edge
  2862.  04h    WORD    source region's top edge
  2863.  06h    WORD    source region's bottom edge
  2864.  08h    WORD    X coordinate of destination region's upper left corner
  2865.  0Ah    WORD    Y coordinate of destination region's upper left corner
  2866. --------V-6200D8-----------------------------
  2867. INT 62 u - FGDRIVER v4.02 - "FG_VBTCXFER" - COPY RECTANGLE TO ACTIVE VIDEO PAGE
  2868.     AX = 00D8h
  2869.     BX = source region's left edge
  2870.     CX = source region's right edge
  2871.     DX = source region's top edge
  2872.     SI = source region's bottom edge
  2873.     DI = X coordinate of destination's upper left corner
  2874.     ES = Y coordinate of destination's upper left corner
  2875. Desc:    copy a rectangle from the active virtual buffer to the active video
  2876.       page, with transparent colors
  2877. Note:    the FGDRIVER functions are rearranged with each major release, but
  2878.       their parameters do not change (see #03474)
  2879. SeeAlso: AX=00D6h,AX=00D7h
  2880. --------V-6200D9-----------------------------
  2881. INT 62 u - FGDRIVER v4.02 - "FG_VBUNDEF" - RELEASE HANDLE FOR VIRTUAL BUFFER
  2882.     AX = 00D9h
  2883.     BX = virtual buffer handle
  2884. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2885.       their parameters do not change (see #03474)
  2886.     the specified handle must not reference the currently-active virtual
  2887.       buffer
  2888. SeeAlso: AX=00D1h,AX=00D5h
  2889. --------V-6200DA-----------------------------
  2890. INT 62 u - FGDRIVER v4.02 - "FG_VGASTATE" - SAVE/RESTORE VGA CONTROLLER STATE
  2891.     AX = 00DAh
  2892.     BX = direction (0000h save, else restore)
  2893. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2894.       their parameters do not change (see #03474)
  2895.     this function is only meaningful in modes 0Dh and above
  2896. --------V-6200DB-----------------------------
  2897. INT 62 u - FGDRIVER v4.02 - "FG_VOICE" - START SOUND
  2898.     AX = 00DBh
  2899.     BX = channel on TI sound chip
  2900.         1-3 = channels 1-3, 4 = channel 4 with periodic noise,
  2901.         5 = channel 4 with white noise
  2902.     CX = frequency in Hz (18-32767 for channels 1-3; 0=512 Hz, 1=1024 Hz,
  2903.           2=2048 Hz for channels 4 and 5)
  2904.     DX = volume
  2905.     SI = duration in clock ticks (continuous if <= 0)
  2906. Program: FGDRIVER is the external video driver for the shareware
  2907.       Fastgraph/Light by Ted Gruber Software
  2908. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2909.       their parameters do not change (see #03474 at AX=0000h)
  2910.     This function is only available on the PCjr and Tandy 1000 machines
  2911. SeeAlso: AX=0080h,AX=00BCh,AX=00DCh
  2912. --------V-6200DC-----------------------------
  2913. INT 62 u - FGDRIVER v4.02 - "FG_VOICES" - PLAY SOUNDS IN BACKGROUND
  2914.     AX = 00DCh
  2915.     ES:BX -> tone array (see #03512)
  2916.     CX = number of times to repeat tone array
  2917. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2918.       their parameters do not change (see #03474 at AX=0000h)
  2919.     This function is only available on the PCjr and Tandy 1000 machines
  2920. SeeAlso: AX=0059h,AX=0081h,AX=00BDh,AX=00DBh
  2921.  
  2922. Format of FGDRIVER tone array element:
  2923. Offset    Size    Description    (Table 03512)
  2924.  00h    WORD    channel number (0000h terminates array)
  2925.  02h    WORD    frequency
  2926.  04h    WORD    volume
  2927.  06h    WORD    duration in 1/72.8 seconds
  2928. --------V-6200DD-----------------------------
  2929. INT 62 u - FGDRIVER v4.02 - "FG_WAITFOR" - DELAY FOR SPECIFIED DURATION
  2930.     AX = 00DDh
  2931.     BX = duration in clock ticks
  2932. Return: after delay elapses
  2933. Note:    the FGDRIVER functions are rearranged with each major release, but
  2934.       their parameters do not change (see #03474 at AX=0000h)
  2935. SeeAlso: AX=00BFh,INT 1A/AX=FF01h
  2936. --------V-6200DE-----------------------------
  2937. INT 62 u - FGDRIVER v4.02 - "FG_WAITKEY" - FLUSH KEYBOARD BUFFER AND AWAIT KEY
  2938.     AX = 00DEh
  2939. Return: after next key pressed
  2940. Note:    the FGDRIVER functions are rearranged with each major release, but
  2941.       their parameters do not change (see #03474 at AX=0000h)
  2942. SeeAlso: AX=000Ah,AX=0046h,AX=0063h,AX=0069h,INT 16/AH=00h
  2943. --------V-6200DF-----------------------------
  2944. INT 62 u - FGDRIVER v4.02 - "FG_WAITVR" - ENABLE/DISABLE VERTICAL RETRACE WAIT
  2945.     AX = 00DFh
  2946.     BX = new state (0000h disabled, 0001h enabled)
  2947. Note:    the FGDRIVER functions are rearranged with each major release, but
  2948.       their parameters do not change (see #03474 at AX=0000h)
  2949. --------V-6200E0-----------------------------
  2950. INT 62 u - FGDRIVER v4.02 - "FG_WHERE" - GET CURRENT CURSOR POSITION
  2951.     AX = 00E0h
  2952.     ES:BX -> variable pointers (see #03513)
  2953. Return: indicated variables filled with cursor row and column for active
  2954.       display
  2955. Note:    the FGDRIVER functions are rearranged with each major release, but
  2956.       their parameters do not change (see #03474 at AX=0000h)
  2957. SeeAlso: AX=0054h,AX=0058h,AX=006Bh,AX=007Eh
  2958.  
  2959. Format of FGDRIVER variable pointers:
  2960. Offset    Size    Description    (Table 03513)
  2961.  00h    WORD    segment of WORD buffer for cursor row
  2962.  02h    WORD    offset of WORD buffer for cursor row
  2963.  04h    WORD    segment WORD buffer for cursor column
  2964.  06h    WORD    offset WORD buffer for cursor column
  2965. --------V-6200E1-----------------------------
  2966. INT 62 u - FGDRIVER v4.02 - "FG_XALPHA" - CONVERT SCREEN COLUMN TO CHAR COLUMN
  2967.     AX = 00E1h
  2968.     BX = screen space column
  2969. Return: AX = character space column containing specified coordinate
  2970. Note:    the FGDRIVER functions are rearranged with each major release, but
  2971.       their parameters do not change (see #03474 at AX=0000h)
  2972. SeeAlso: AX=00E2h,AX=00E4h
  2973. --------V-6200E2-----------------------------
  2974. INT 62 u - FGDRIVER v4.02 - "FG_XCONVERT" - CONVERT CHAR COLUMN TO SCREEN COL
  2975.     AX = 00E2h
  2976.     BX = character space column
  2977. Return: AX = screen space column of leftmost pixel in specified character col
  2978. Note:    the FGDRIVER functions are rearranged with each major release, but
  2979.       their parameters do not change (see #03474 at AX=0000h)
  2980. SeeAlso: AX=00E2h,AX=00E5h
  2981. --------V-6200E3-----------------------------
  2982. INT 62 u - FGDRIVER v4.02 - "FG_XVIEW" - CONVERT VIEWPORT COORDINATE
  2983.     AX = 00E3h
  2984.     BX = horizontal viewport coordinate
  2985. Return: AX = screen space X coordinate corresponding to supplied coordinate
  2986. Notes:    the FGDRIVER functions are rearranged with each major release, but
  2987.       their parameters do not change (see #03474 at AX=0000h)
  2988.     if no viewport has been defined, the returned coordinate will be the
  2989.       same as the viewport coordinate
  2990. SeeAlso: AX=00E2h,AX=00E6h
  2991. --------V-6200E4-----------------------------
  2992. INT 62 u - FGDRIVER v4.02 - "FG_YALPHA" - CONVERT SCREEN ROW TO CHARACTER ROW
  2993.     AX = 00E4h
  2994.     BX = screen space row
  2995. Return: AX = character space row containing specified coordinate
  2996. Note:    the FGDRIVER functions are rearranged with each major release, but
  2997.       their parameters do not change (see #03474 at AX=0000h)
  2998. SeeAlso: AX=00E1h,AX=00E5h
  2999. --------V-6200E5-----------------------------
  3000. INT 62 u - FGDRIVER v4.02 - "FG_YCONVERT" - CONVERT CHARACTER ROW TO SCREEN ROW
  3001.     AX = 00E5h
  3002.     BX = character space row
  3003. Return: AX = screen space row of topmost pixel in specified character row
  3004. Note:    the FGDRIVER functions are rearranged with each major release, but
  3005.       their parameters do not change (see #03474 at AX=0000h)
  3006. SeeAlso: AX=00E2h,AX=00E4h,AX=00E6h
  3007. --------V-6200E6-----------------------------
  3008. INT 62 u - FGDRIVER v4.02 - "FG_YVIEW" - TRANSLATE VERTICAL VIEWPORT COORDINATE
  3009.     AX = 00E6h
  3010.     BX = viewport Y coordinate
  3011. Return: AX = screen space row for viewport coordinate
  3012. Program: FGDRIVER is the external video driver for the shareware
  3013.       Fastgraph/Light by Ted Gruber Software
  3014. Notes:    the FGDRIVER functions are rearranged with each major release, but
  3015.       their parameters do not change (see #03474 at AX=0000h)
  3016.     if no viewport has been defined, the returned coordinate will be the
  3017.       same as the viewport coordinate
  3018. SeeAlso: AX=00E3h,AX=00E5h
  3019. --------T-6201-------------------------------
  3020. INT 62 - Cswitch - GIVE UP REST OF TIME-SLICE
  3021.     AH = 01h
  3022. Program: Cswitch is a set of multitasking functions by Herb Rose
  3023. SeeAlso: AH=05h"Cswitch",AH=06h"Cswitch",INT 15/AX=1000h,INT 2F/AX=1680h
  3024. --------N-6201-------------------------------
  3025. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - NOP for ETHDEV.ODI
  3026.     AH = 01h
  3027. Return: CF clear if successful
  3028.     CF set on error
  3029.         AL = error code
  3030. Range:    INT 4C to INT FB, selected by configuration
  3031. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3032. SeeAlso: INT 64/AH=01h"BW-NFS"
  3033. --------T-6202-------------------------------
  3034. INT 62 - Cswitch - WAIT FOR SEMAPHORE
  3035.     AH = 02h
  3036.     DX = semaphore number (0-63)
  3037. Return: AX = FFFFh bad semaphore number
  3038.          else  success
  3039. SeeAlso: AH=03h"Cswitch",AH=04h"Cswitch"
  3040. --------N-6202-------------------------------
  3041. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - INITIALIZE
  3042.     AH = 02h
  3043. Return: CF clear if successful
  3044.     CF set on error
  3045.         AL = error code
  3046. SeeAlso: AH=00h"ETHDEV",AH=03h"ETHDEV",AH=FEh,INT 21/AH=3Fh"BW-TCP"
  3047. SeeAlso: INT 63/AH=03h"BW-TCP",INT 63/AH=24h"BW-TCP",INT 64/AH=01h"BW-NFS"
  3048. --------T-6203-------------------------------
  3049. INT 62 - Cswitch - CHECK SEMAPHORE
  3050.     AH = 03h
  3051.     DX = semaphore number (0-63)
  3052. Return: AX = status
  3053.         FFFFh not owned
  3054.         else  owned
  3055. SeeAlso: AH=02h,AH=04h
  3056. --------N-6203-------------------------------
  3057. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - GET REAL IP ADDRESS
  3058.     AH = 03h
  3059.     DS:SI -> DWORD buffer for IP address
  3060. Return: CF clear if successful
  3061.     CF set on error
  3062.         AL = error code
  3063. Range:    INT 4C to INT FB, selected by configuration
  3064. Note:    the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3065.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3066.       consecutive interrupt (64h by default) if it is loaded
  3067. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3068. SeeAlso: INT 64/AH=01h"BW-NFS"
  3069. --------T-6204-------------------------------
  3070. INT 62 - Cswitch - TRIGGER SEMAPHORE
  3071.     AH = 04h
  3072.     DX = semaphore number (0-63)
  3073. Return: AX = status
  3074.         FFFFh bad semaphore number
  3075.         else  success
  3076. SeeAlso: AH=02h"Cswitch",AH=03h"Cswitch"
  3077. --------N-6204-------------------------------
  3078. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - SET ???
  3079.     AH = 04h
  3080.     BX = ???
  3081.     ES:SI -> FAR routine for ???
  3082. Return: CF clear if successful
  3083.     CF set on error
  3084.         AL = error code
  3085. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3086. SeeAlso: INT 64/AH=01h"BW-NFS"
  3087. --------T-6205-------------------------------
  3088. INT 62 - Cswitch - SLEEP
  3089.     AH = 05h
  3090.     BX = seconds to sleep
  3091. SeeAlso: AH=01h"Cswitch",AH=06h"Cswitch",AH=08h"Cswitch"
  3092. --------N-6205-------------------------------
  3093. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - ???
  3094.     AH = 05h
  3095.     ???
  3096. Return: CF clear if successful
  3097.     CF set on error
  3098.         AL = error code
  3099. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3100. SeeAlso: INT 64/AH=01h"BW-NFS"
  3101. --------T-6206-------------------------------
  3102. INT 62 - Cswitch - SUSPEND
  3103.     AH = 06h
  3104. SeeAlso: AH=05h"Cswitch",AH=08h"Cswitch"
  3105. --------N-6206-------------------------------
  3106. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - ???
  3107.     AH = 06h
  3108.     ???
  3109. Return: CF clear if successful
  3110.     CF set on error
  3111.         AL = error code
  3112. Range:    INT 4C to INT FB, selected by configuration
  3113. Note:    the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3114.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3115.       consecutive interrupt (64h by default) if it is loaded
  3116. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3117. SeeAlso: INT 64/AH=01h"BW-NFS"
  3118. --------T-6207-------------------------------
  3119. INT 62 - Cswitch - SPAWN
  3120.     AH = 07h
  3121.     ES:BX -> function address to start executing at
  3122.     CX = priority (1-10)
  3123. Return: AX = result/status
  3124.         FFFDh  no free memory control blocks
  3125.         FFFEh  no free task control blocks
  3126.         FFFFh  not enough memory to create new task stack
  3127.         >0       the tcb number of the new task, indicating no error
  3128. SeeAlso: AH=0Fh"Cswitch",AH=10h"Cswitch"
  3129. --------N-6207-------------------------------
  3130. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - ???
  3131.     AH = 07h
  3132.     DS:SI -> ???
  3133. Return: CF clear if successful
  3134.     CF set on error
  3135.         AL = error code
  3136. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3137. SeeAlso: INT 64/AH=01h"BW-NFS"
  3138. --------T-6208-------------------------------
  3139. INT 62 - Cswitch - WAKE UP TASK
  3140.     AH = 08h
  3141.     BX = tcb identifier
  3142. SeeAlso: AH=05h,AH=06h
  3143. --------N-6208-------------------------------
  3144. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - ???
  3145.     AH = 08h
  3146.     CX = ???
  3147.     ES:SI -> ??? buffer (see #03514)
  3148. Return: CF clear if successful
  3149.     CF set on error
  3150.         AL = error code
  3151. Range:    INT 4C to INT FB, selected by configuration
  3152. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3153. SeeAlso: INT 64/AH=01h"BW-NFS"
  3154.  
  3155. Format of BW-TCP ??? buffer:
  3156. Offset    Size    Description    (Table 03514)
  3157.  00h  6 BYTEs    hardware address???
  3158.  06h  6 BYTEs    ???
  3159.  0Ch    WORD    ???
  3160.  0Eh    WORD    ???
  3161. ----------6208--CXFFFE-----------------------
  3162. INT 62 - MS SQL Server/Sybase DBLIBRARY interface - UNINSTALL/GET PSP ADDR
  3163.     AH = 08h
  3164.     CX = FFFEh
  3165.     DX = FFFFh
  3166. Return: AX = PSP address of resident DBLIBRARY
  3167. Note:    this call does not free the memory allocated to the TSR; the calling
  3168.       code must do the deallocation.
  3169. SeeAlso: INT 62"DBLIBRARY"
  3170. --------T-6209-------------------------------
  3171. INT 62 - Cswitch - SET PRIORITY
  3172.     AH = 09h
  3173.     BX = new base priority (1-10)
  3174. Note:    the lower the priority is numerically, the more often the task will run
  3175. --------N-6209-------------------------------
  3176. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - HOOK TIMER INTERRUPT
  3177.     AH = 09h
  3178. Return: CF clear if successful
  3179.         AX = handler ID
  3180.     CF set on error
  3181.         AL = error code
  3182. Range:    INT 4C to INT FB, selected by configuration
  3183. Note:    the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3184.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3185.       consecutive interrupt (64h by default) if it is loaded
  3186. SeeAlso: AH=0Ah"ETHDEV",AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3187. SeeAlso: INT 64/AH=01h"BW-NFS"
  3188. --------T-620A-------------------------------
  3189. INT 62 - Cswitch - TEST MESSAGE QUEUE
  3190.     AH = 0Ah
  3191.     DX = queue number (0-63)
  3192. Return: AX = result/message size
  3193.         0000h nothing on queue
  3194.         FFFFh bad queue number
  3195.         else  number of bytes in first message in queue
  3196. SeeAlso: AH=0Bh"Cswitch",AH=0Ch"Cswitch"
  3197. --------N-620A-------------------------------
  3198. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - UNHOOK TIMER INTERRUPT
  3199.     AH = 0Ah
  3200.     DX = handler ID
  3201. Return: CF clear if successful
  3202.     CF set on error
  3203.         AL = error code
  3204. SeeAlso: AH=09h"ETHDEV",AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3205. SeeAlso: INT 64/AH=01h"BW-NFS"
  3206. --------T-620B-------------------------------
  3207. INT 62 - Cswitch - SEND MESSAGE
  3208.     AH = 0Bh
  3209.     CX = number of bytes to write
  3210.     DS:SI -> buffer
  3211.     DX = queue number (0-63)
  3212. Return: AX = result/message size
  3213.         0000h no message was on queue
  3214.         FFFEh triggered by something arriving, redo the call
  3215.         FFFFh bad queue number
  3216.         else  number of bytes in message
  3217. SeeAlso: AH=0Ah"Cswitch",AH=0Ch"Cswitch"
  3218. --------N-620B-------------------------------
  3219. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - ADD ???
  3220.     AH = 0Bh
  3221.     AL = ???
  3222.     DX = ???
  3223.     BP = ???
  3224.     ES:SI -> ???
  3225. Return: CF clear if successful
  3226.     CF set on error
  3227.         AL = error code
  3228. SeeAlso: AH=0Ch"ETHDEV",AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3229. SeeAlso: INT 64/AH=01h"BW-NFS"
  3230. --------T-620C-------------------------------
  3231. INT 62 - Cswitch - READ MESSAGE
  3232.     AH = 0Ch
  3233.     CX = number of bytes to read
  3234.     DS:SI -> buffer
  3235.     DX = queue number (0-63)
  3236. Return: AX = status
  3237.         FFFFh bad queue number
  3238.         else  number of bytes transferred
  3239. SeeAlso: AH=0Ah,AH=0Bh
  3240. --------N-620C-------------------------------
  3241. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - REMOVE ???
  3242.     AH = 0Ch
  3243.     DX = ???
  3244.     BP = ???
  3245. Return: CF clear if successful
  3246.     CF set on error
  3247.         AL = error code
  3248. Range:    INT 4C to INT FB, selected by configuration
  3249. Note:    the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3250.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3251.       consecutive interrupt (64h by default) if it is loaded
  3252. SeeAlso: AH=0Bh"ETHDEV",AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3253. SeeAlso: INT 64/AH=01h"BW-NFS"
  3254. --------T-620D-------------------------------
  3255. INT 62 - Cswitch - DON'T ALLOW TASK TO BE SWAPPED OUT
  3256.     AH = 0Dh
  3257. SeeAlso: AH=0Eh"Cswitch"
  3258. --------N-620D-------------------------------
  3259. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - NOP for ETHDEV.ODI
  3260.     AH = 0Dh
  3261. Return: CF clear if successful
  3262.     CF set on error
  3263.         AL = error code
  3264. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3265. SeeAlso: INT 64/AH=01h"BW-NFS"
  3266. --------T-620E-------------------------------
  3267. INT 62 - Cswitch - ALLOW TASK TO BE SWAPPED OUT
  3268.     AH = 0Eh
  3269. SeeAlso: AH=0Dh"Cswitch"
  3270. --------N-620E-------------------------------
  3271. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - BEGIN CRITICAL SECTION
  3272.     AH = 0Eh
  3273. Return: CF clear if successful
  3274.     CF set on error
  3275.         AL = error code
  3276. SeeAlso: AH=0Fh"ETHDEV",AH=10h"ETHDEV",AH=FEh,INT 21/AH=3Fh"BW-TCP"
  3277. SeeAlso: INT 63/AH=03h"BW-TCP",INT 63/AH=24h"BW-TCP",INT 64/AH=01h"BW-NFS"
  3278. --------T-620F-------------------------------
  3279. INT 62 - Cswitch - LOAD AND RUN PROGRAM FROM DISK
  3280.     AH = 0Fh
  3281.     ES:BX -> command line
  3282.     CX = priority (1-10)
  3283.     DX = background flag (nonzero allows loading to EMS)
  3284. Return: AX = status
  3285.         0000h task loader queue is full
  3286.         0001h  no error
  3287. SeeAlso: AH=07h"Cswitch",AH=10h"Cswitch",AH=13h"Cswitch"
  3288. --------N-620F-------------------------------
  3289. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - END CRITICAL SECTION
  3290.     AH = 0Fh
  3291. Return: CF clear if successful
  3292.     CF set on error
  3293.         AL = error code
  3294. Range:    INT 4C to INT FB, selected by configuration
  3295. Note:    the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3296.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3297.       consecutive interrupt (64h by default) if it is loaded
  3298. SeeAlso: AH=0Eh"ETHDEV",AH=10h"ETHDEV",AH=FEh,INT 21/AH=3Fh"BW-TCP"
  3299. SeeAlso: INT 63/AH=03h"BW-TCP",INT 63/AH=24h"BW-TCP",INT 64/AH=01h"BW-NFS"
  3300. --------T-6210-------------------------------
  3301. INT 62 - Cswitch - TERMINATE SPAWNED PROGRAM
  3302.     AH = 10h
  3303. SeeAlso: AH=07h"Cswitch",AH=0Fh"Cswitch"
  3304. --------N-6210-------------------------------
  3305. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - QUERY CRITICAL SECTION
  3306.     AH = 10h
  3307. Return: CF clear if no critical section active
  3308.     CF set if in critical section
  3309. SeeAlso: AH=0Eh"ETHDEV",AH=0Fh"ETHDEV",AH=FEh,INT 21/AH=3Fh"BW-TCP"
  3310. SeeAlso: INT 63/AH=03h"BW-TCP",INT 63/AH=24h"BW-TCP",INT 64/AH=01h"BW-NFS"
  3311. --------T-6211-------------------------------
  3312. INT 62 - Cswitch - GET TCB INFORMATION
  3313.     AH = 11h
  3314.     ES:BX -> a pointer which will be set to the tcb address
  3315. Return: AX = tcb indentifier
  3316. SeeAlso: AH=12h
  3317. --------N-6211-------------------------------
  3318. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - SET ???
  3319.     AH = 11h
  3320.     ES:SI -> ???
  3321. Return: CF clear
  3322. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3323. SeeAlso: INT 64/AH=01h"BW-NFS"
  3324. --------T-6212-------------------------------
  3325. INT 62 - Cswitch - GET TCB ADDRESS
  3326.     AH = 12h
  3327.     ES:BX -> a pointer which will be set to the tcb table address
  3328. Return: AX = tcb indentifier
  3329. SeeAlso: AH=11h"Cswitch"
  3330. --------N-6212-------------------------------
  3331. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - GET SOCKET NUMBER???
  3332.     AH = 12h
  3333. Return: CF clear if successful
  3334.         AX = socket number??? (memory variable incremented after reading)
  3335.     CF set on error
  3336.         AL = error code
  3337. Range:    INT 4C to INT FB, selected by configuration
  3338. Note:    the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3339.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3340.       consecutive interrupt (64h by default) if it is loaded
  3341. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3342. SeeAlso: INT 64/AH=01h"BW-NFS"
  3343. --------T-6213-------------------------------
  3344. INT 62 - Cswitch - CHECK STATUS OF PREVIOUS LOAD_TASK
  3345.     AH = 13h
  3346. Return: AX = result
  3347.         FFFCh no Memory Control Blocks available
  3348.         FFFDh no TCBs available
  3349.         FFFEh insufficient memory
  3350.         FFFFh cannot open file
  3351.         0000h load in progress (not done yet)
  3352.         else  tcb indentifier
  3353. SeeAlso: AH=0Fh
  3354. --------N-6213-------------------------------
  3355. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - ???
  3356.     AH = 13h
  3357.     CX = ???
  3358. Return: CF clear if successful
  3359.         AL = 00h
  3360.     CF set on error
  3361.         AL = error code
  3362. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3363. SeeAlso: INT 64/AH=01h"BW-NFS"
  3364. --------N-6214-------------------------------
  3365. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - ???
  3366.     AH = 14h
  3367.     ES:SI -> ???
  3368. Return: CF clear if successful
  3369.         AL = 00h
  3370.     CF set on error
  3371.         AL = error code
  3372. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3373. SeeAlso: INT 64/AH=01h"BW-NFS"
  3374. --------N-6215-------------------------------
  3375. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - GET ???
  3376.     AH = 15h
  3377. Return: CF clear if successful
  3378.         AX = ??? (destroyed???)
  3379.     CF set on error
  3380.         AL = error code
  3381. Range:    INT 4C to INT FB, selected by configuration
  3382. Notes:    call this function after reading the "ETHDEV27" device
  3383.     the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3384.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3385.       consecutive interrupt (64h by default) if it is loaded
  3386. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3387. INT 64/AH=01h"BW-NFS"
  3388. --------N-6216-------------------------------
  3389. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - ???
  3390.     AH = 16h
  3391.     ???
  3392. Return: CF clear if successful
  3393.     CF set on error
  3394.         AL = error code
  3395. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3396. SeeAlso: INT 64/AH=01h"BW-NFS"
  3397. --------N-6217-------------------------------
  3398. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - ???
  3399.     AH = 17h
  3400.     DX = segment of ???
  3401. Return: CF clear
  3402. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=24h"BW-TCP"
  3403. SeeAlso: INT 64/AH=01h"BW-NFS"
  3404. --------N-6218-------------------------------
  3405. INT 62 - BW-TCP - HW DRIVER (ETHDEV.SYS) - ALLOCATE AND MAP EMS FOR DRIVER
  3406.     AH = 18h
  3407. Return: CF clear if successful
  3408.     CF set on error
  3409.         AL = error code
  3410. Range:    INT 4C to INT FB, selected by configuration
  3411. Notes:    calls function 17h after EMS allocated and mapped
  3412.     the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3413.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3414.       consecutive interrupt (64h by default) if it is loaded
  3415. SeeAlso: AH=FEh,INT 21/AH=3Fh"BW-TCP",INT 63/AH=03h"BW-TCP",INT 63/AH=24h
  3416. SeeAlso: INT 64/AH=01h"BW-NFS"
  3417. --------R-6247-------------------------------
  3418. INT 62 - PC Tools v7 COMMUTE - ???
  3419.     AH = 47h
  3420.     AL = subfunction (00h-31h)
  3421.     ???
  3422.     CF set
  3423. Return: ???
  3424. Program: COMMUTE is a remote-control program bundled with Central Point
  3425.       Software's PC Tools
  3426. --------R-6248-------------------------------
  3427. INT 62 - PC Tools v7 COMMUTE - ???
  3428.     AH = 48h
  3429.     AL = ???
  3430.     ???
  3431.     CF set
  3432. Return: ???
  3433. --------R-6249-------------------------------
  3434. INT 62 - PC Tools v7 COMMUTE - ???
  3435.     AH = 49h
  3436.     ???
  3437.     CF set
  3438. Return: ???
  3439. Note:    may be the same as AH=4Ch
  3440. --------R-624A-------------------------------
  3441. INT 62 - PC Tools v7 COMMUTE - ???
  3442.     AH = 4Ah
  3443.     AL = subfunction (00h-46h)
  3444.     ???
  3445.     CF set
  3446. Return: ???
  3447. --------R-624B--BX1234-----------------------
  3448. INT 62 - PC Tools v7 COMMUTE - ???
  3449.     AH = 4Bh
  3450.     BX = 1234h
  3451.     CX = 1234h
  3452.     ES = ???
  3453.     CF set
  3454. Return: ???
  3455. Program: COMMUTE is a remote-control program bundled with Central Point
  3456.       Software's PC Tools
  3457. --------R-624C-------------------------------
  3458. INT 62 - PC Tools v7 COMMUTE - ???
  3459.     AH = 4Ch
  3460.     BL = subfunction
  3461.         00h ???
  3462.         02h ???
  3463. Return: CF clear if successful
  3464.     CF set on error
  3465. --------R-626262-----------------------------
  3466. INT 62 - PC Tools v7 COMMUTE - INSTALLATION CHECK
  3467.     AX = 6262h
  3468.     CF set
  3469. Return: AX = 0000h
  3470.     BX = segment of resident code's PSP
  3471. Program: COMMUTE is a remote-control program bundled with Central Point
  3472.       Software's PC Tools
  3473. --------s-62C0-------------------------------
  3474. INT 62 U - GWBTSR - API
  3475.     AH = C0h
  3476.     AL = function
  3477.         00h installation check
  3478.         Return: AX = 00FFh if installed
  3479.         01h ???
  3480. Program: GWBTSR is a huge (48K) resident mixer controller for the Gateway 2000
  3481.       sound card (OEM version of Aztech Sound Galaxy)
  3482. Index:    installation check;GWBTSR
  3483. --------N-62FE-------------------------------
  3484. INT 62 - BW-TCP - ETHDRV.SYS - MAP EMS PAGE FRAME
  3485.     AH = FEh
  3486.     AL = direction
  3487.         00h map in driver's memory block
  3488.         01h map out driver's memory block
  3489. Return: CF clear if successful
  3490.     CF set on error
  3491.         AL = error code
  3492. Range:    INT 4C to INT FB, selected by configuration
  3493. Notes:    this function is supported by at least the SLIP and ODI versions of
  3494.       ETHDEV.SYS
  3495.     the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3496.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3497.       consecutive interrupt (64h by default) if it is loaded
  3498. SeeAlso: INT 21/AH=3Fh"BW-TCP",INT 62/AH=00h"ETHDEV",INT 62/AH=18h"ETHDEV"
  3499. SeeAlso: INT 63/AH=03h"BW-TCP",INT 63/AH=24h,INT 64/AH=FEh
  3500. --------*-63---------------------------------
  3501. INT 63 - reserved for user interrupt
  3502. --------d-63---------------------------------
  3503. INT 63 - Adaptec and OMTI controllers - DRIVE 0 DATA
  3504. Desc:    this vector stores the last four bytes of the parameter table for
  3505.       hard disk 0
  3506. SeeAlso: INT 60"Adaptec",INT 61"Adaptec",INT 62"Adaptec",INT 64"Adaptec"
  3507. --------b-63---------------------------------
  3508. INT 63 - TI Professional PC - OPTION ROM DATA AREA POINTER (NOT A VECTOR!)
  3509. Desc:    the low word of this vector contains the segment of the RAM data area
  3510.       to be used by the expansion ROM at F400h:4000h, and the high word
  3511.       contains the length of the data area; this segment and size are
  3512.       both set to 0000h if no ROM is installed at F400h:4000h
  3513. SeeAlso: INT 60"TI Professional PC",INT 62"TI Professional"
  3514. SeeAlso: INT 64"TI Professional PC"
  3515. ----------63---------------------------------
  3516. INT 63 - Oracle SQL Protected Mode Executive - ???
  3517. --------d-63---------------------------------
  3518. INT 63 - 4+Power FLOPPY CONTROLLER - ORIGINAL INT 13/40
  3519. Desc:    the "4+Power" quad floppy controller BIOS hooks INT 13 (or INT 40 if
  3520.       INT 13 has been moved there) and places the old value here
  3521. ----------63---------------------------------
  3522. INT 63 - Kofax KF9X00 image manipulation card interface
  3523. --------Q-63---------------------------------
  3524. INT 63 - DESQview/X - SOCKET API
  3525. InstallCheck:    test for the string "dvxunix" (yes, lowercase) at offset 9
  3526.       from the interrupt handler start (see #03515)
  3527. Notes:    parameters are passed by patching (!) data field immediately following
  3528.       the entry point, as detailed below (see #03515); the preferred
  3529.       method for calling the socket API is via INT 15/AX=DE2Eh
  3530. SeeAlso: INT 15/AX=DE2Eh,INT BE"DESQview"
  3531. Index:    installation check;DESQview/X socket interface
  3532.  
  3533. Format of DESQview/X socket interrupt handler entry:
  3534. Offset    Size    Description    (Table 03515)
  3535.  00h  3 BYTEs    near jump or short jump + NOP to actual interrupt handler
  3536.  03h    WORD    offset from following pointer for initial top of local stack
  3537.  05h    DWORD    pointer to argument/stack block (see INT 15/AX=DE2Eh)
  3538.  09h  7 BYTEs    signature "dvxunix"
  3539. --------b-6300-------------------------------
  3540. INT 63 - HP 100LX - MAP HIGH MEMORY
  3541.     AH = 00h
  3542.     AL = physical page (00h seg C000, 01h seg C400h, ...)
  3543.     BX = zero-based logical page
  3544.     CX = page number
  3545.     DX = device ID (00h system ROM, 05h plugin, etc.)
  3546. Return: ???
  3547. SeeAlso: AH=01h
  3548. --------N-6300-------------------------------
  3549. INT 63 - BW-TCP - TCPIP.SYS - SET IP ADDRESS???
  3550.     AH = 00h
  3551.     DS:BX -> DWORD containing IP address (big-endian)
  3552. Return: CF clear if successful
  3553.     CF set on error
  3554.     AX destroyed
  3555. Range:    INT 4D to INT FC, selected by configuration
  3556. Note:    the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3557.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3558.       consecutive interrupt (64h by default) if it is loaded
  3559. SeeAlso: AH=01h"BW-TCP",AH=02h"BW-TCP"
  3560. --------b-6301-------------------------------
  3561. INT 63 - HP 100LX - SAVE/RESTORE MEMORY MAP
  3562.     AH = 01h
  3563.     AL = function (00h save, 01h restore)
  3564.     ???
  3565. Return: ???
  3566. --------N-6301-------------------------------
  3567. INT 63 - BW-TCP - TCPIP.SYS - ???
  3568.     AH = 01h
  3569.     ES:BX -> ???
  3570.     ???
  3571. Return: ???
  3572. Range:    INT 4D to INT FC, selected by configuration
  3573. Note:    the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3574.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3575.       consecutive interrupt (64h by default) if it is loaded
  3576. SeeAlso: AH=00h"BW-TCP",AH=02h"BW-TCP"
  3577. --------N-6302-------------------------------
  3578. INT 63 - BW-TCP - TCPIP.SYS - ???
  3579.     AH = 02h
  3580.     ???
  3581. Return: ???
  3582. SeeAlso: AH=00h"BW-TCP",AH=01h"BW-TCP"
  3583. --------N-6303-------------------------------
  3584. INT 63 - BW-TCP - TCPIP.SYS - GET IP ADDRESS
  3585.     AH = 03h
  3586.     DS:SI -> buffer for DWORD IP address (big-endian)
  3587. Return: AX destroyed
  3588.     CF clear if successful
  3589.     CF set on error
  3590. Note:    this call may use ARP or RARP to determine the address
  3591. --------N-6304-------------------------------
  3592. INT 63 - BW-TCP - TCPIP.SYS - ???
  3593.     AH = 04h
  3594.     ???
  3595. Return: ???
  3596. --------N-6305-------------------------------
  3597. INT 63 - BW-TCP - TCPIP.SYS - ???
  3598.     AH = 05h
  3599.     DS:BX -> ???
  3600.     ES:SI -> ???
  3601. Return: ???
  3602. Range:    INT 4D to INT FC, selected by configuration
  3603. --------N-6306-------------------------------
  3604. INT 63 - BW-TCP - TCPIP.SYS - ???
  3605.     AH = 06h
  3606.     ???
  3607. Return: ???
  3608. --------N-6307-------------------------------
  3609. INT 63 - BW-TCP - TCPIP.SYS - ???
  3610.     AH = 07h
  3611.     ???
  3612. Return: ???
  3613. --------N-6308-------------------------------
  3614. INT 63 - BW-TCP - TCPIP.SYS - SET DEFAULT ??? HANDLER
  3615.     AH = 08h
  3616.     DS:BX -> DWORD containing IP address
  3617. Return: CF clear if successful
  3618.     CF set on error
  3619.     ???
  3620. --------N-6309-------------------------------
  3621. INT 63 - BW-TCP - TCPIP.SYS - INSTALL ??? HANDLERS
  3622.     AH = 09h
  3623.     BL = handler type
  3624.     ES:SI -> FAR handler of specified type
  3625. Return: ???
  3626. SeeAlso: AH=0Ah,AH=0Dh
  3627. --------N-630A-------------------------------
  3628. INT 63 - BW-TCP - TCPIP.SYS - DELETE ??? HANDLERS
  3629.     AH = 0Ah
  3630.     BL = handler type
  3631. Return: CF clear if successful
  3632.     CF set on error (no handler of specified type installed)
  3633. SeeAlso: AH=09h
  3634. --------N-630B-------------------------------
  3635. INT 63 - BW-TCP - TCPIP.SYS - ???
  3636.     AH = 0Bh
  3637.     AL = ???
  3638.     DL = ???
  3639.     DS:BX -> ???
  3640.     ES:SI -> ???
  3641. Return: ???
  3642. --------N-630C-------------------------------
  3643. INT 63 - BW-TCP - TCPIP.SYS - ???
  3644.     AH = 0Ch
  3645.     ???
  3646. Return: ???
  3647. Range:    INT 4D to INT FC, selected by configuration
  3648. --------N-630D-------------------------------
  3649. INT 63 - BW-TCP - TCPIP.SYS - INSTALL DEFAULT ??? HANDLER
  3650.     AH = 0Dh
  3651.     ???
  3652. Return: ???
  3653. Note:    if not already installed, installs a type 06h handler with AH=09h
  3654. SeeAlso: AH=09h
  3655. --------N-630E-------------------------------
  3656. INT 63 - BW-TCP - TCPIP.SYS - CLOSE NETWORK DESCRIPTOR
  3657.     AH = 0Eh
  3658.     ???
  3659. Return: ???
  3660. SeeAlso: INT 61/AH=08h"PC/TCP",INT 61/AH=09h"PC/TCP",INT 61/AH=18h
  3661. --------N-630F-------------------------------
  3662. INT 63 - BW-TCP - TCPIP.SYS - ???
  3663.     AH = 0Fh
  3664.     AL = ???
  3665.     SI = ???
  3666.     DS:DI -> ???
  3667.     ???
  3668. Return: ???
  3669. Range:    INT 4D to INT FC, selected by configuration
  3670. --------N-6310-------------------------------
  3671. INT 63 - BW-TCP - TCPIP.SYS - ???
  3672.     AH = 10h
  3673.     DS:DI -> ???
  3674.     ???
  3675. Return: ???
  3676. --------N-6311-------------------------------
  3677. INT 63 - BW-TCP - TCPIP.SYS - ???
  3678.     AH = 11h
  3679.     ???
  3680. Return: ???
  3681. --------N-6312-------------------------------
  3682. INT 63 - BW-TCP - TCPIP.SYS - LISTEN FOR INCOMING CONNECTIONS
  3683.     AH = 12h
  3684.     DS:SI -> ???
  3685.     ES:BP -> ???
  3686. Return: ???
  3687. SeeAlso: AH=14h,INT 61/AH=23h
  3688. --------N-6313-------------------------------
  3689. INT 63 - BW-TCP - TCPIP.SYS - NOP
  3690.     AH = 13h
  3691. Return: nothing
  3692. Range:    INT 4D to INT FC, selected by configuration
  3693. --------N-6314-------------------------------
  3694. INT 63 - BW-TCP - TCPIP.SYS - OPEN NETWORK CONNECTION
  3695.     AH = 14h
  3696.     BX = network descriptor???
  3697.     DS:SI -> ???
  3698.     ES:BP -> ???
  3699. Return: ???
  3700. SeeAlso: AH=12h,AH=16h,AH=19h,INT 61/AH=13h"PC/TCP",INT 62/AH=13h"ETHDEV"
  3701. --------N-6315-------------------------------
  3702. INT 63 - BW-TCP - TCPIP.SYS - ???
  3703.     AH = 15h
  3704.     DS:DI -> ???
  3705.     ???
  3706. Return: ???
  3707. Range:    INT 4D to INT FC, selected by configuration
  3708. --------N-6316-------------------------------
  3709. INT 63 - BW-TCP - TCPIP.SYS - RESET NETWORK CONNECTION
  3710.     AH = 16h
  3711.     DS:DI -> ???
  3712. Return: ???
  3713. Note:    calls AH=17h after preprocessing
  3714. SeeAlso: AH=17h,INT 61/AH=19h"PC/TCP"
  3715. --------N-6317-------------------------------
  3716. INT 63 - BW-TCP - TCPIP.SYS - ???
  3717.     AH = 17h
  3718.     DS:DI -> ???
  3719.     ???
  3720. Return: ???
  3721. Range:    INT 4D to INT FC, selected by configuration
  3722. SeeAlso: AH=18h
  3723. --------N-6318-------------------------------
  3724. INT 63 - BW-TCP - TCPIP.SYS - ???
  3725.     AH = 18h
  3726.     DS:DI -> ???
  3727.     ???
  3728. Return: ???
  3729. Note:    same as AH=17h, except performed with interrupts disabled
  3730. SeeAlso: AH=17h
  3731. --------N-6319-------------------------------
  3732. INT 63 - BW-TCP - TCPIP.SYS - WRITE TO THE NETWORK
  3733.     AH = 19h
  3734.     DS:DI -> ???
  3735.     ???
  3736. Return: BX = number of bytes NOT written
  3737.     ???
  3738. Range:    INT 4D to INT FC, selected by configuration
  3739. Note:    calls AH=17h with interrupts disabled and ??? set to 01h
  3740. SeeAlso: AH=14h,AH=1Ah,AH=1Bh,INT 61/AH=1Ah"PC/TCP"
  3741. --------N-631A-------------------------------
  3742. INT 63 - BW-TCP - TCPIP.SYS - READ FROM THE NETWORK
  3743.     AH = 1Ah
  3744.     CX = maximum number of bytes to read
  3745.     ES:BP -> ???
  3746.     ???
  3747. Return: CX = number of bytes actually read
  3748.     ???
  3749. SeeAlso: AH=12h,AH=14h,AH=19h,INT 61/AH=1Bh"PC/TCP"
  3750. --------N-631B-------------------------------
  3751. INT 63 - BW-TCP - TCPIP.SYS - ???
  3752.     AH = 1Bh
  3753.     CX = ???
  3754.     ES:BP -> ???
  3755. Return: DX = ???
  3756.     ???
  3757. Range:    INT 4D to INT FC, selected by configuration
  3758. --------N-631C-------------------------------
  3759. INT 63 - BW-TCP - TCPIP.SYS - ???
  3760.     AH = 1Ch
  3761.     DS:DI -> ???
  3762.     ???
  3763. Return: ???
  3764. Note:    calls AH=17h with ???
  3765. SeeAlso: AH=17h
  3766. --------N-631D-------------------------------
  3767. INT 63 - BW-TCP - TCPIP.SYS - ???
  3768.     AH = 1Dh
  3769.     ???
  3770. Return: ???
  3771. Range:    INT 4D to INT FC, selected by configuration
  3772. --------N-631E-------------------------------
  3773. INT 63 - BW-TCP - TCPIP.SYS - ???
  3774.     AH = 1Eh
  3775.     DS:BX -> DWORD containing IP address (big-endian)
  3776.     ???
  3777. Return: CF clear if successful
  3778.     CF set on error
  3779.     ???
  3780. --------N-631F-------------------------------
  3781. INT 63 - BW-TCP - TCPIP.SYS - SET SOCKET ??? HANDLER
  3782.     AH = 1Fh
  3783.     BX = socket number
  3784.     ES:SI -> FAR function for ???
  3785. Return: CF clear if successful
  3786.     CF set on error (out of slots)
  3787. SeeAlso: AH=20h
  3788. --------N-6320-------------------------------
  3789. INT 63 - BW-TCP - TCPIP.SYS - REMOVE SOCKET ??? HANDLER
  3790.     AH = 20h
  3791.     BX = socket number
  3792. Return: CF clear if successful
  3793.     CF set on error (not set)
  3794. Range:    INT 4D to INT FC, selected by configuration
  3795. SeeAlso: AH=1Fh
  3796. --------N-6321-------------------------------
  3797. INT 63 - BW-TCP - TCPIP.SYS - ???
  3798.     AH = 21h
  3799.     ES:SI -> ???
  3800. Return: ???
  3801. SeeAlso: INT 61/AH=1Ch"PC/TCP"
  3802. --------N-6322-------------------------------
  3803. INT 63 - BW-TCP - TCPIP.SYS - REMOVE ??? HANDLER
  3804.     AH = 22h
  3805. Return: CF clear
  3806. Range:    INT 4D to INT FC, selected by configuration
  3807. Note:    decrements a counter if not already zero, and calls AH=0Ah with BL=11h
  3808.       if the counter reaches zero
  3809. --------N-6323-------------------------------
  3810. INT 63 - BW-TCP - TCPIP.SYS - ???
  3811.     AH = 23h
  3812.     DS:BX -> ???
  3813.     ES:SI -> 6-byte buffer for ???
  3814. Return: CF clear if successful
  3815.     CF set on error
  3816. --------N-6324-------------------------------
  3817. INT 63 - BW-TCP - TCPIP.SYS - GET SOCKET
  3818.     AH = 24h
  3819. Return: AX = socket number (0400h-FFFFh)
  3820. Range:    INT 4D to INT FC, selected by configuration
  3821. Note:    the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3822.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3823.       consecutive interrupt (64h by default) if it is loaded
  3824. SeeAlso: AH=12h,AH=14h,INT 62/AH=12h"ETHDEV",INT 64/AH=01h"BW-NFS"
  3825. --------N-6325-------------------------------
  3826. INT 63 - BW-TCP - TCPIP.SYS - GET INTERNET ADDRESS
  3827.     AH = 25h
  3828. Return: CL:CH:DL:DH = caller's Internet address
  3829. SeeAlso: AH=03h,AH=26h,INT 61/AH=05h"PC/TCP"
  3830. --------N-6326-------------------------------
  3831. INT 63 - BW-TCP - TCPIP.SYS - SET INTERNET ADDRESS???
  3832.     AH = 26h
  3833.     CL:CH:DL:DH = Internet address
  3834. Return: nothing
  3835. Range:    INT 4D to INT FC, selected by configuration
  3836. Note:    this function sets a different variable than AH=25h returns
  3837. SeeAlso: AH=03h,AH=25h
  3838. --------N-6327-------------------------------
  3839. INT 63 - BW-TCP - TCPIP.SYS - SET ???
  3840.     AH = 27h
  3841.     BX = ???
  3842.     ES:SI -> ???
  3843. Return: ???
  3844. --------N-6328-------------------------------
  3845. INT 63 - BW-TCP - TCPIP.SYS - ???
  3846.     AH = 28h
  3847.     ???
  3848. Return: ???
  3849. --------N-6329-------------------------------
  3850. INT 63 - BW-TCP - TCPIP.SYS - ???
  3851.     AH = 29h
  3852.     ???
  3853. Return: ???
  3854. Range:    INT 4D to INT FC, selected by configuration
  3855. Note:    the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3856.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3857.       consecutive interrupt (64h by default) if it is loaded
  3858. --------*-64---------------------------------
  3859. INT 64 - reserved for user interrupt
  3860. --------d-64---------------------------------
  3861. INT 64 - Adaptec controllers - DRIVE 1 DATA
  3862. Desc:    this vector stores the first four bytes of the parameter table for
  3863.       hard disk 1
  3864. Notes:    these vectors are used by the following Adaptec controllers:
  3865.         ACB 2370 A/B/C, ACB 2372 A/B/C, ACB 2333 A/B, 2322B-8, 2322B-16
  3866.     these vectors are NOT used by the following Adaptec controllers:
  3867.         ACB 2310, ACB 2312, ACB 2320D, ACB 2322D
  3868. SeeAlso: INT 60"Adaptec",INT 65"Adaptec",INT 66"Adaptec",INT 67"Adaptec"
  3869. --------b-64---------------------------------
  3870. INT 64 - TI Professional PC - OPTION ROM DATA AREA POINTER (NOT A VECTOR!)
  3871. Desc:    the low word of this vector contains the segment of the RAM data area
  3872.       to be used by the expansion ROM at F400h:6000h, and the high word
  3873.       contains the length of the data area; this segment and size are
  3874.       both set to 0000h if no ROM is installed at F400h:6000h
  3875. SeeAlso: INT 60"TI Professional PC",INT 63"TI Professional"
  3876. SeeAlso: INT 65"TI Professional PC"
  3877. ----------64---------------------------------
  3878. INT 64 - Oracle SQL Protected Mode Executive - ???
  3879. --------N-64---------------------------------
  3880. INT 64 - Novell NetWare to v2.0a - LOW-LEVEL API
  3881. Note:    equivalent to INT 7A for NetWare versions through 2.0a only; later
  3882.       versions do not use this interrupt for IPX/SPX access, instead
  3883.       getting an entry point from INT 2F/AX=7A00h
  3884. SeeAlso: INT 2F/AX=7A00h,INT 7A"LOW-LEVEL API"
  3885. --------h-64---------------------------------
  3886. INT 64 - Data General DG10 - MicroECLIPSE COPROCESSOR INTERFACE
  3887. SeeAlso: INT 65"DG10",INT 66"DG10"
  3888. --------r-64---------------------------------
  3889. INT 64 - Extended Batch Language v3.14+
  3890.     AH = function
  3891.         00h to 5Fh chained to previous handler
  3892.         60h to 6Ch reserved, return immediately
  3893.         80h to FFh chained to previous handler
  3894.         6Dh (v4.01+) insert tone in queue
  3895.         AL = ???
  3896.         CX = frequency in Hertz
  3897.         DL = duration in clock ticks
  3898.         Return: AL = 00h if note stored
  3899.                = 01h if no room to store
  3900.         6Eh clear ??? counter/flag
  3901.         6Fh return counter/flag that AH=6Eh clears
  3902.         70h ???
  3903.         AL = ???
  3904.         71h ???
  3905.         AL = ???
  3906.         72h ???
  3907.         73h insert byte at end of keyboard buffer
  3908.         AL = byte to insert
  3909.         Return: AL = 00h if byte inserted
  3910.                = 01h if no room to store
  3911.         74h insert byte at front of keyboard buffer
  3912.         AL = byte to insert
  3913.         Return: AL = 00h if byte inserted
  3914.                = 01h if no room to store
  3915.         75h ???
  3916.         76h get keyboard "stack" status
  3917.         AL = 'K' if kbd read will read physical keyboard
  3918.              'S' if it will read EBL internal keyboard buffer
  3919.         AH = ???
  3920.         77h clear internal keyboard buffer
  3921.         78h ???
  3922.         AL = ???
  3923.         79h ???
  3924.         7Ah ???
  3925.         AL = ???
  3926.         7Bh ???
  3927.         AL = ???
  3928.         7Ch ???
  3929.         AL = ???
  3930.         7Dh ???
  3931.         AL = ???
  3932.         7Eh clear buffer for ???
  3933.         7Fh installation check
  3934.         Return: CX = version in BCD
  3935.             DI = segment of ???
  3936.             BX = segment of next program's PSP???
  3937. Program: Extended Batch Language is a batch-file enhancer by Seaware
  3938. Notes:    the chaining does not check whether the interrupt had been hooked
  3939.       before, so if you try to chain when the previous vector was
  3940.       0000h:0000h, you'll be in trouble
  3941.     functions 72h and 7Ah-7Dh appear to be interfaces to the optional
  3942.       floating-point and extended function packages
  3943. Index:    installation check;EBL|installation check;Extended Batch Language
  3944. --------d-64---------------------------------
  3945. INT 64 - Pdisk by Scott Garfinkle - Overwritten for Hard Drive information
  3946. Note:    This vector is overwritten by Pdisk to install custom harddrive types.
  3947.       It can either destroy 4 vectors and take no memory or TSR and take
  3948.       up some memory.
  3949. SeeAlso: INT 65"Pdisk"
  3950. ----------64---------------------------------
  3951. INT 64 - PC-DRAFT - ASYNCHRONOUS DRIVER
  3952.     ???
  3953. Return: ???
  3954. Program: PC-DRAFT is a powerful CAD environment by rhv.
  3955. SeeAlso: INT 62"PC-DRAFT",INT 65"PC-DRAFT",INT 66"PC-DRAFT",INT 67"PC-DRAFT"
  3956. --------N-6401-------------------------------
  3957. INT 64 U - BW-NFS - BWRPC - ???
  3958.     AH = 01h
  3959.     ES:BX -> ??? (at least 8 bytes)
  3960.     ES:BP -> DWORD ???
  3961.     ???
  3962. Return: CF clear if successful
  3963.         ???
  3964.     CF set on error
  3965.         CX = 0000h
  3966. Range:    INT 4E to INT FD, selected by configuration
  3967. Notes:    the Beame&Whiteside TCP/IP protocol stack uses two consecutive
  3968.       interrupts (62h and 63h by default); the BW-NFS client uses a third
  3969.       consecutive interrupt (64h by default) if it is loaded
  3970.     the BWRPC installation check consists of determining the interrupt
  3971.       vector assigned to it (two more than the value returned by reading
  3972.       the ETHDEV27 device), and testing whether the word immediately
  3973.       preceding the interrupt handler is 4257h ('BW')
  3974. SeeAlso: INT 62/AH=00h"ETHDEV",INT 63/AH=03h"BW-TCP",INT 63/AH=24h
  3975. Index:    installation checks;BWRPC
  3976. --------N-6402-------------------------------
  3977. INT 64 U - BW-NFS - BWRPC - ???
  3978.     AH = 02h
  3979.     DS:DI -> ???
  3980. Return: ???
  3981. Note:    this call is passed directly through to INT 62/AH=07h
  3982. SeeAlso: INT 62/AH=07h"ETHDEV"
  3983. --------N-6403-------------------------------
  3984. INT 64 U - BW-NFS - BWRPC - ADD ???
  3985.     AH = 03h
  3986.     AL = ???
  3987.     BP = ???
  3988.     ES:SI -> ???
  3989. Return: ???
  3990. Note:    this call is passed directly through to INT 62/AH=0Bh
  3991. SeeAlso: AH=04h,INT 62/AH=0Bh"ETHDEV"
  3992. --------N-6404-------------------------------
  3993. INT 64 U - BW-NFS - BWRPC - REMOVE ???
  3994.     AH = 04h
  3995.     BP = ???
  3996. Return: ???
  3997. Range:    INT 4E to INT FD, selected by configuration
  3998. Note:    this call is passed directly through to INT 62/AH=0Ch
  3999. SeeAlso: AH=03h,INT 62/AH=0Ch"ETHDEV"
  4000. --------N-6405-------------------------------
  4001. INT 64 U - BW-NFS - BWRPC - ???
  4002.     AH = 05h
  4003.     CX = ???
  4004. Return: ???
  4005. Note:    this call is passed directly through to INT 62/AH=13h
  4006. SeeAlso: INT 62/AH=13h"ETHDEV"
  4007. --------N-6406-------------------------------
  4008. INT 64 U - BW-NFS - BWRPC - ???
  4009.     AH = 06h
  4010.     ES:SI -> ???
  4011. Return: AL = 00h if CF clear
  4012. Range:    INT 4E to INT FD, selected by configuration
  4013. Note:    this call is passed directly through to INT 62/AH=14h
  4014. SeeAlso: INT 62/AH=14h"ETHDEV"
  4015. --------N-6407-------------------------------
  4016. INT 64 U - BW-NFS - BWRPC - GET IP ADDRESS
  4017.     AH = 07h
  4018. Return: CX:DX = IP address
  4019. --------N-6410-------------------------------
  4020. INT 64 U - BW-NFS - BWRPC - CALL ETHDEV.SYS
  4021.     AH = 10h
  4022.     AL = ETHDEV function number
  4023.     other registers as appropriate for ETHDEV call
  4024. Return: as returned by ETHDEV
  4025. Note:    this call is passed directly through to INT 62
  4026. SeeAlso: INT 62/AH=00h"ETHDEV"
  4027. --------N-6411-------------------------------
  4028. INT 64 U - BW-NFS - BWRPC - NOP???
  4029.     AH = 11h
  4030. Return: CF clear
  4031. Range:    INT 4E to INT FD, selected by configuration
  4032. --------N-64FE-------------------------------
  4033. INT 64 - BW-NFS - BWRPC - MAP EMS PAGE FRAME
  4034.     AH = FEh
  4035.     AL = direction
  4036.         00h map in driver's memory block
  4037.         01h map out driver's memory block
  4038. Return: CF clear if successful
  4039.     CF set on error
  4040.         AL = error code
  4041. Range:    INT 4E to INT FD, selected by configuration
  4042. Note:    this call is passed through directly to ETHDEV.SYS (see INT 62/AH=FEh)
  4043. SeeAlso: INT 21/AH=3Fh"BW-TCP",INT 62/AH=FEh,INT 63/AH=03h"BW-TCP"
  4044. SeeAlso: INT 63/AH=24h
  4045. --------*-65---------------------------------
  4046. INT 65 - reserved for user interrupt
  4047. --------d-65---------------------------------
  4048. INT 65 - Adaptec controllers - DRIVE 1 DATA
  4049. Desc:    this vector stores the second four bytes of the parameter table for
  4050.       hard disk 1
  4051. SeeAlso: INT 64"Adaptec",INT 66"Adaptec",INT 67"Adaptec"
  4052. --------b-65---------------------------------
  4053. INT 65 - TI Professional PC - OPTION ROM DATA AREA POINTER (NOT A VECTOR!)
  4054. Desc:    the low word of this vector contains the segment of the RAM data area
  4055.       to be used by the expansion ROM at F400h:8000h, and the high word
  4056.       contains the length of the data area; this segment and size are
  4057.       both set to 0000h if no ROM is installed at F400h:8000h
  4058. SeeAlso: INT 60"TI Professional PC",INT 64"TI Professional"
  4059. SeeAlso: INT 66"TI Professional PC"
  4060. --------h-65---------------------------------
  4061. INT 65 - Data General DG10 - MicroECLIPSE COPROCESSOR INTERFACE
  4062. SeeAlso: INT 64"DG10",INT 66"DG10"
  4063. --------N-65---------------------------------
  4064. INT 65 - FTP Software NDIS-Packet Driver adapter - POST PROCESSING INTERRUPT
  4065. --------U-65---------------------------------
  4066. INT 65 - SD.COM v6.2
  4067. Desc:    The unregistered version of SD62.COM uses the low byte of this vector
  4068.       to count the number of invocations, displaying a registration
  4069.       reminder each time after the 20th use.
  4070. --------d-65---------------------------------
  4071. INT 65 - Pdisk by Scott Garfinkle - Overwritten for Hard Drive information
  4072. SeeAlso: INT 64"Pdisk",INT 66"Pdisk"
  4073. ----------65---------------------------------
  4074. INT 65 - PC-DRAFT - SECONDARY DISPLAY DRIVER
  4075.     ???
  4076. Return: ???
  4077. Program: PC-DRAFT is a powerful CAD environment by rhv.
  4078. SeeAlso: INT 62"PC-DRAFT",INT 64"PC-DRAFT",INT 66"PC-DRAFT",INT 67"PC-DRAFT"
  4079. --------s-65---------------------------------
  4080. INT 65 - Ad Lib SOUND.COM - INTERFACE
  4081.     SI = function number (also see separate entries below)
  4082.         0000h Init
  4083.         0002h RelTimeStart
  4084.         0003h SetState
  4085.         0004h GetState
  4086.         0005h Flush
  4087.         0006h SetMode
  4088.         0007h GetMode
  4089.         0008h SetRelVolume
  4090.         0009h SetTempo
  4091.         000Ah SetTranspose
  4092.         000Bh GetTranspose
  4093.         000Ch SetActVoice
  4094.         000Dh GetActVoice
  4095.         000Eh PlayNoteDel
  4096.         000Fh PlayNote
  4097.         0010h SetTimbre
  4098.         0011h SetPitch
  4099.         0012h SetTickBeat
  4100.         0013h NoteOn
  4101.         0014h NoteOff
  4102.         0015h Timbre
  4103.         0016h SetPitchBend
  4104.         0017h WaveForm
  4105.     ES:BX -> arguments
  4106. InstallCheck:    test for the signature block immediately preceding the
  4107.       interrupt handler (see #03516)
  4108. SeeAlso: SI=8000h
  4109. Index:    installation check;Ad Lib SOUND.COM
  4110.  
  4111. Format of AdLib signature block:
  4112. Offset    Size    Description    (Table 03516)
  4113.  00h    WORD    version number
  4114.  02h 19 BYTEs    "SOUND-DRIVER-AD-LIB"
  4115.  15h    BYTE    01h
  4116.  16h    BYTE    01h
  4117.  17h    BYTE    00h
  4118. --------N-65----DX4147-----------------------
  4119. INT 65 U - NetSoft DOS-NET v1.20+ - ??? API
  4120.     DX = 4147h
  4121.     BH = 01h
  4122.     BL = function number (00h-2Ah)
  4123.     ???
  4124. Return: CF clear if successful
  4125.         AX = ???
  4126.     CF set on error
  4127.         AX = error code (0001h=invalid function/subfunction)
  4128. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4129.       number and function number may be retrieved via INT 2A/AX=4147h
  4130. Note:    this API is supported by CLIENT.COM, SERVER.COM, DOSNET.COM, and
  4131.       ROUTER.COM
  4132. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4133. --------N-65----DX4147-----------------------
  4134. INT 65 U - NetSoft DOS-NET v1.20+ - ??? API
  4135.     DX = 4147h
  4136.     BH = 02h
  4137.     BL = function number (00h-05h)
  4138.     ???
  4139. Return: CF clear if successful
  4140.         AX = ???
  4141.     CF set on error
  4142.         AX = error code (0001h=invalid function/subfunction)
  4143. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4144.       number and function number may be retrieved via INT 2A/AX=4147h
  4145. Note:    this API is supported by CLIENT.COM, SERVER.COM, DOSNET.COM, and
  4146.       ROUTER.COM
  4147. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4148. --------N-65----DX4147-----------------------
  4149. INT 65 U - NetSoft DOS-NET v1.20+ - ??? API
  4150.     DX = 4147h
  4151.     BH = 03h
  4152.     BL = function number (00h-03h) (00h-04h for ROUTER.COM)
  4153.     ???
  4154. Return: CF clear if successful
  4155.         AX = ???
  4156.     CF set on error
  4157.         AX = error code
  4158. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4159.       number and function number may be retrieved via INT 2A/AX=4147h
  4160. Note:    this API is supported by CLIENT.COM, SERVER.COM, DOSNET.COM, and
  4161.       ROUTER.COM
  4162. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4163. --------N-65----DX4147-----------------------
  4164. INT 65 U - NetSoft DOS-NET v1.20+ - ??? API
  4165.     DX = 4147h
  4166.     BH = 04h
  4167.     BL = function number (00h-07h)
  4168.     ???
  4169. Return: CF clear if successful
  4170.         AX = ???
  4171.     CF set on error
  4172.         AX = error code
  4173. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4174.       number and function number may be retrieved via INT 2A/AX=4147h
  4175. Note:    this API is supported by CLIENT.COM, SERVER.COM, and DOSNET.COM
  4176. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4177. --------N-65----DX4147-----------------------
  4178. INT 65 U - NetSoft DOS-NET v1.20+ - ??? API
  4179.     DX = 4147h
  4180.     BH = 07h
  4181.     BL = function number (00h-08h)
  4182.     ???
  4183. Return: CF clear if successful
  4184.         AX = ???
  4185.     CF set on error
  4186.         AX = error code (0001h=invalid function/subfunction)
  4187. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4188.       number and function number may be retrieved via INT 2A/AX=4147h
  4189. Note:    this API is supported by CLIENT.COM, SERVER.COM, and DOSNET.COM
  4190. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4191. --------N-65----DX4147-----------------------
  4192. INT 65 U - NetSoft DOS-NET v1.20+ - INSTALLATION CHECK???
  4193.     DX = 4147h
  4194.     BH = 80h
  4195. Return: CF set
  4196.     AX = 0001h
  4197. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4198.       number and function number may be retrieved via INT 2A/AX=4147h
  4199. Note:    this call is supported by CLIENT.COM, SERVER.COM, and ROUTER.COM
  4200. SeeAlso: DX=4147h,INT 2A/AX=4147h
  4201. --------N-65----DX4741-----------------------
  4202. INT 65 U - NetSoft DOS-NET v1.20+ - SPOOLER - ???
  4203.     DX = 4741h
  4204.     BH = 01h
  4205.     AL = 02h
  4206.     BL = function number (0Eh,0Fh)
  4207.     AH = subfunction number
  4208.     ???
  4209. Return: ???
  4210. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4211.       number may be retrieved via INT 2A/AX=4147h
  4212. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4213. --------N-65----DX4741-----------------------
  4214. INT 65 U - NetSoft DOS-NET v1.20+ - PRNREDIR - ???
  4215.     DX = 4741h
  4216.     BH = 01h
  4217.     AL = 03h
  4218.     BL = function number (0Eh,0Fh)
  4219.     AH = subfunction number
  4220.     ???
  4221. Return: ???
  4222. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4223.       number may be retrieved via INT 2A/AX=4147h
  4224. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4225. --------N-65----DX4741-----------------------
  4226. INT 65 U - NetSoft DOS-NET v1.20+ - PRNREDIR - ???
  4227.     DX = 4741h
  4228.     BH = 01h
  4229.     AL = 04h
  4230.     BL = function number (0Eh,0Fh)
  4231.     AH = subfunction number
  4232.     ???
  4233. Return: ???
  4234. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4235.       number may be retrieved via INT 2A/AX=4147h
  4236. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4237. --------N-65----DX4741-----------------------
  4238. INT 65 U - NetSoft DOS-NET v1.20+ - NETBIOS - ???
  4239.     DX = 4741h
  4240.     BH = 01h
  4241.     AL = 07h
  4242.     BL = function number (0Eh,0Fh)
  4243.     AH = subfunction number
  4244.     ???
  4245. Return: ???
  4246. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4247.       number may be retrieved via INT 2A/AX=4147h
  4248. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4249. --------N-65----DX4741-----------------------
  4250. INT 65 U - NetSoft DOS-NET v1.20+ - MACTEST - ???
  4251.     DX = 4741h
  4252.     BH = 01h
  4253.     AL = 08h
  4254.     BL = function number (0Eh,0Fh)
  4255.     AH = subfunction number
  4256.     ???
  4257. Return: ???
  4258. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4259.       number may be retrieved via INT 2A/AX=4147h
  4260. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4261. --------N-65----DX4741-----------------------
  4262. INT 65 U - NetSoft DOS-NET v1.20+ - Physical Layer - ???
  4263.     DX = 4741h
  4264.     BH = 02h
  4265.     BL = function number (01h-04h)
  4266.     ???
  4267. Return: ???
  4268.     ---function 02h---
  4269.     DS:SI -> ??? data area
  4270. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4271.       number may be retrieved via INT 2A/AX=4147h
  4272. Note:    this API is supported by PARALLEL.COM, SERIAL.COM, ARCNET.COM,
  4273.       ETHERNET.COM, NDIS.COM, ODI.COM, SMC.COM, and FTP.COM
  4274. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4275. --------N-65----DX4741-----------------------
  4276. INT 65 U - NetSoft DOS-NET v1.20+ - SPOOLER.COM - ???
  4277.     DX = 4741h
  4278.     BH = 05h
  4279.     BL = function number (00h,01h)
  4280. Return: CF clear
  4281.     AL = status code (00h=successful)
  4282. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4283.       number may be retrieved via INT 2A/AX=4147h
  4284. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4285. --------N-65----DX4741-----------------------
  4286. INT 65 U - NetSoft DOS-NET v1.20+ - PRNREDIR.COM - ???
  4287.     DX = 4741h
  4288.     BH = 06h
  4289.     BL = function number (00h-04h)
  4290.     ???
  4291. Return: ???
  4292. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4293.       number may be retrieved via INT 2A/AX=4147h
  4294. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4295. --------N-65----DX4741-----------------------
  4296. INT 65 U - NetSoft DOS-NET v1.20+ - COMREDIR.COM - ???
  4297.     DX = 4741h
  4298.     BH = 08h
  4299.     BL = function number (00h-01h)
  4300.     ???
  4301. Return: ???
  4302. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4303.       number may be retrieved via INT 2A/AX=4147h
  4304. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4305. --------N-65----DX4741-----------------------
  4306. INT 65 U - NetSoft DOS-NET v1.20+ - FTP.COM - ???
  4307.     DX = 4741h
  4308.     BX = 8010h
  4309.     AL = instance number???
  4310. Return: AX = 0008h if AL matches internal variable (call chained otherwise)
  4311. Range:    INT ?? to INT ??, selected by configuration option; actual interrupt
  4312.       number may be retrieved via INT 2A/AX=4147h
  4313. SeeAlso: DX=4147h"INSTALLATION",INT 2A/AX=4147h
  4314. --------s-65----SI0000-----------------------
  4315. INT 65 - Ad Lib SOUND.COM - INITIALIZE (RESET)
  4316.     SI = 0000h
  4317. --------s-65----SI0003-----------------------
  4318. INT 65 - Ad Lib SOUND.COM - SET STATE
  4319.     SI = 0003h
  4320.     ES:BX -> WORD new state (0000h disabled, 0001h enabled)
  4321. SeeAlso: SI=0004h
  4322. --------s-65----SI0004-----------------------
  4323. INT 65 - Ad Lib SOUND.COM - GET STATE
  4324.     SI = 0004h
  4325. Return: AX = status
  4326.         0000h all done playing sounds
  4327.         else  still playing sounds
  4328. SeeAlso: SI=0003h
  4329. --------s-65----SI0006-----------------------
  4330. INT 65 - Ad Lib SOUND.COM - SET MODE
  4331.     SI = 0006h
  4332.     ES:BX -> WORD new mode (0000h melodic, 0001h percussive)
  4333. SeeAlso: SI=0007h
  4334. --------s-65----SI0007-----------------------
  4335. INT 65 - Ad Lib SOUND.COM - GET MODE
  4336.     SI = 0007h
  4337. Return: AX = mode
  4338.         0000h melodic
  4339.         0001h percussive
  4340. SeeAlso: SI=0006h
  4341. --------s-65----SI000C-----------------------
  4342. INT 65 - Ad Lib SOUND.COM - SET ACTIVE VOICE
  4343.     SI = 000Ch
  4344.     ES:BX -> WORD voice = 0000h to 0008h
  4345. SeeAlso: SI=000Dh
  4346. --------s-65----SI000D-----------------------
  4347. INT 65 - Ad Lib SOUND.COM - GET ACTIVE VOICE
  4348.     SI = 000Dh
  4349. Return: AX = voice (0000h to 0008h)
  4350. SeeAlso: SI=000Ch
  4351. --------s-65----SI8000-----------------------
  4352. INT 65 u - Media Vision FM.COM v4.1a+ - GET INTERNAL DATA STRUCTURES
  4353.     SI = 8000h
  4354. Return: DX:AX -> internal data structures
  4355. Program: FM.COM is an Ad Lib SOUND.COM-compatible driver for Media Vision's
  4356.       Pro Audio Spectrum sound boards
  4357. SeeAlso: SI=8001h
  4358. --------s-65----SI8001-----------------------
  4359. INT 65 u - Media Vision FM.COM v4.1a+ - GET VOICE COUNT
  4360.     SI = 8001h
  4361. Return: AX = ???
  4362.     DX = number of voices??? (09h or 0Bh)
  4363. SeeAlso: SI=8000h
  4364. --------s-65----SI8002-----------------------
  4365. INT 65 - Media Vision FM.COM v4.1a+ - START BACKGROUND FM SOUNDS
  4366.     SI = 8002h
  4367. SeeAlso: SI=8003h
  4368. --------s-65----SI8003-----------------------
  4369. INT 65 - Media Vision FM.COM v4.1a+ - STOP BACKGROUND FM SOUNDS
  4370.     SI = 8003h
  4371. SeeAlso: SI=8002h
  4372. --------s-65----SI8004-----------------------
  4373. INT 65 U - Media Vision FM.COM v4.1a+ - GET ???
  4374.     SI = 8004h
  4375. Return: AX = ??? (0280h)
  4376.     DX = ??? (01A0h)
  4377. --------s-65----SI8005-----------------------
  4378. INT 65 U - Media Vision FM.COM v4.1a+ - ???
  4379.     SI = 8005h
  4380.     ???
  4381. Return: ???
  4382. SeeAlso: SI=8000h
  4383. --------S-65---------------------------------
  4384. INT 65 U - EZRECV v1.0 - API
  4385.     AX = function
  4386.         0000h ???
  4387.         Return: AX = ??? or FFFFh
  4388.         0001h ???
  4389.         Return: AX = status (0000h or 0001h)
  4390.         0002h ???
  4391.         Return: AX = status (0000h or 0001h)
  4392.         0003h set ??? to 0001h
  4393.         Return: AX = 0000h
  4394.         0004h ???
  4395.         Return: AX = ???
  4396. Return: BH = COM port being used
  4397.     BL = speed???
  4398.     CH = ???
  4399.     CL = ???
  4400.     DX = ???
  4401.     DS = ???
  4402.     ES = EZRECV data segment
  4403. Program: EZRECV is a background Zmodem file receiver by Express Consulting
  4404. --------*-66---------------------------------
  4405. INT 66 - reserved for user interrupt
  4406. --------d-66---------------------------------
  4407. INT 66 - Adaptec controllers - DRIVE 1 DATA
  4408. Desc:    this vector stores the third four bytes of the parameter table for
  4409.       hard disk 1
  4410. SeeAlso: INT 64"Adaptec",INT 65"Adaptec",INT 67"Adaptec"
  4411. --------b-66---------------------------------
  4412. INT 66 - TI Professional PC - SYSTEM INFORMATION (NOT A VECTOR!)
  4413. Desc:    the low word of this vector contains the system memory size in
  4414.       paragraphs; the third byte contains the number of outstanding
  4415.       interrupt requests, and the fourth byte contains a description
  4416.       of the installed drive types (see #03517)
  4417. SeeAlso: INT 60"TI Professional PC",INT 67"TI Professional"
  4418.  
  4419. Bitfields for TI Professional drive type information:
  4420. Bit(s)    Description    (Table 03517)
  4421.  7    floppy drive D: has 80 tracks
  4422.  6    floppy drive D: is double-sided
  4423.  5    floppy drive C: has 80 tracks
  4424.  4    floppy drive C: is double-sided
  4425.  3    floppy drive B: has 80 tracks
  4426.  2    floppy drive B: is double-sided
  4427.  1    floppy drive A: has 80 tracks
  4428.  0    floppy drive A: is double-sided
  4429. --------h-66---------------------------------
  4430. INT 66 - Data General DG10 - MicroECLIPSE COPROCESSOR INTERFACE
  4431. SeeAlso: INT 64"DG10"
  4432. --------N-66---------------------------------
  4433. INT 66 C - Nanosoft, Inc. TurboNET - NETWORK PROCESSING ???
  4434. Program: TurboNET is a NetBIOS-based file redirector and server
  4435. Note:    hooked but not used (IRET) by both redirector and server; called from
  4436.       server's INT 28 handler
  4437. SeeAlso: INT 2F/AX=8100h
  4438. --------d-66---------------------------------
  4439. INT 66 - Pdisk by Scott Garfinkle - Overwritten for Hard Drive information
  4440. SeeAlso: INT 64"Pdisk",INT 67"Pdisk"
  4441. --------W-66---------------------------------
  4442. INT 66 - Microsoft Windows VITD.386 Virtual Interval Timer
  4443. Note:    This Windows 3.x Virtual Device Driver implements a virtual timer
  4444.       which will expire and call INT 66.  This timer can be used to
  4445.       calculate elapsed execution time etc.
  4446. --------K-66---------------------------------
  4447. INT 66 - Newkey v5.4 - INSTALLATION VECTOR
  4448. Return: immediately (IRET)
  4449. Program: Newkey is a shareware keyboard macro program by Frank A. Bell
  4450. InstallCheck:    test for the signature bytes FDh FCh FFh FEh at offset 03h in
  4451.       the interrupt handlers segment
  4452. Range:    INT 60h to INT 67h, selected by scanning for highest unused vector
  4453. BUG:    the code obviously intends to use INT F0-FE, INT 70-77, and INT 68-6F
  4454.       before falling back to INT 60-67, but only uses the last of these
  4455.       ranges in v5.4
  4456. SeeAlso: INT 2F/AX=E300h
  4457. Index: installation checks;Newkey|Newkey;installation check
  4458. ----------66---------------------------------
  4459. INT 66 - PC-DRAFT - TABLET/DIGITIZER DRIVER
  4460.     ???
  4461. Return: ???
  4462. Program: PC-DRAFT is a powerful CAD environment by rhv.
  4463. SeeAlso: INT 62"PC-DRAFT",INT 64"PC-DRAFT",INT 65"PC-DRAFT",INT 67"PC-DRAFT"
  4464. --------U-66---------------------------------
  4465. INT 66 - PC-Magazin - INCA
  4466.     details not yet availble
  4467. Program: INCA is a utility from PC-Magazin (the German edition of PC Magazine)
  4468.       issue 51-52/85.
  4469. SeeAlso: INT 61"SWAPx"
  4470. --------F-6601-------------------------------
  4471. INT 66 - BitFax Scheduler - SET MODE???
  4472.     AH = 01h
  4473. SeeAlso: AH=02h
  4474. --------F-6602-------------------------------
  4475. INT 66 - BitFax Scheduler - SET MODE???
  4476.     AH = 02h
  4477. SeeAlso: AH=01h
  4478. --------F-6603-------------------------------
  4479. INT 66 - BitFax Scheduler - SCHEDULE FAX TRANSMISSIONS
  4480.     AH = 03h
  4481.     ???
  4482. Return: ???
  4483. SeeAlso: AH=05h
  4484. --------F-6604-------------------------------
  4485. INT 66 - BitFax Scheduler - GET STATUS???
  4486.     AH = 04h
  4487. Return: AX = ??? (0000h or 0001h)
  4488.     DX = BitSched version???  (for versions >= 3.00)
  4489.         9796h (ver. 3.00)
  4490.         97E6h (ver. 3.02)
  4491.         92D0h (ver. 3.04.06)
  4492.         9510h (ver. 3.06.02)
  4493. SeeAlso: AH=06h,AX=3345h,INT 2F/AX=8000h"FaxBIOS"
  4494. --------F-6605-------------------------------
  4495. INT 66 - BitFax Scheduler - CONVERT FILE AND SEND FAX
  4496.     AH = 05h
  4497.     BX:CX -> command block (see #03518)
  4498.     ???
  4499. Return: ???
  4500. SeeAlso: AH=03h
  4501.  
  4502. Format of BitFax command block:
  4503. Offset    Size    Description    (Table 03518)
  4504.  00h 18 BYTEs    configuration bytes???
  4505.  12h    BYTEs    ASCIZ temporary file name to place converted fax
  4506.  52h    BYTEs    ASCIZ directory containing BitFax executables
  4507.  92h    BYTEs    ASCIZ telephone number
  4508.  C2h    BYTE    cover page control (00h don't send, 01h do send cover page)
  4509.  C3h 15 BYTEs    configuration bytes???
  4510.  E2h    BYTEs    ASCIZ path of BITFAX.TRA file (containing additional
  4511.           configuration information???)
  4512. 122h    BYTEs    configuration bytes???
  4513. 12Ch    BYTE    00h don't send cover page
  4514.         01h send cover page
  4515. 12Dh  7 BYTEs    configuration bytes???
  4516. 134h    BYTEs    ASCIZ path of file to send
  4517. 174h    BYTEs    more configuration bytes???
  4518.     ???
  4519. --------F-6606-------------------------------
  4520. INT 66 - BitFax Scheduler - SET MODE???
  4521.     AH = 06h
  4522. Return: DX = BitSched version??? (same as AH=04h)
  4523. SeeAlso: AH=04h
  4524. --------s-660688-----------------------------
  4525. INT 66 - IBMSND driver, DIGPAK - PLAY 8-BIT DIGITIZED SOUND
  4526.     AX = 0688h
  4527.     DS:SI -> SNDSTRUC (see #03519)
  4528. Return: ???
  4529. Program: The IBMSND driver is part of John W. Ratcliff's
  4530.        The IBM Digitized Sound Package
  4531.     DIGPAK is a set of digitized sound drivers written by
  4532.       John W. Ratcliff, The Audio Solution, Inc.
  4533. InstallCheck:    test for a valid signature string six bytes prior to the
  4534.       interrupt handler; this string may be either "KERN" or "MIDI" (in
  4535.       the latter case, call AX=0701h to determine whether IBMSND is
  4536.       installed)
  4537. SeeAlso: AX=068Bh,AX=068Fh,AX=0701h
  4538.  
  4539. Format of IBMSND driver SNDSTRUC:
  4540. Offset    Size    Description    (Table 03519)
  4541.  00h    DWORD    -> audio data
  4542.  04h    WORD    length of audio data in bytes
  4543.  06h    DWORD    -> playback status flag
  4544.  0Ah    WORD    playback frequency
  4545. --------s-660689-----------------------------
  4546. INT 66 - IBMSND driver, DIGPAK - REPORT SOUND DRIVER STATUS
  4547.     AX = 0689h
  4548. Return: AX = status
  4549.         0000h no sound playing
  4550.         0001h sound effect is currently playing
  4551.     ---DIGPAK---
  4552.     BX = version number (v3.1+)
  4553.     DX = looping status
  4554.         0000h no sound looping
  4555.         0001h sound effect is currently looping
  4556. SeeAlso: AX=0688h,AX=068Bh,AX=068Ch
  4557. Index:    version check;DIGPAK
  4558. --------s-66068A-----------------------------
  4559. INT 66 - IBMSND driver, DIGPAK - PREFORMAT SOUND
  4560.     AX = 068Ah
  4561.     DS:SI -> SNDSTRUC (see #03519)
  4562. Desc:    convert audio data into output hardware format
  4563. SeeAlso: AX=068Bh
  4564. --------s-66068B-----------------------------
  4565. INT 66 - IBMSND driver, DIGPAK - PLAY PREFORMATTED SOUND
  4566.     AX = 068Bh
  4567.     DS:SI -> SNDSTRUC (see #03519)
  4568. Return: AX = ???
  4569. SeeAlso: AX=0688h,AX=068Ah,AX=068Fh
  4570. --------s-66068C-----------------------------
  4571. INT 66 - IBMSND driver, DIGPAK - REPORT AUDIO DRIVER CAPABILITIES
  4572.     AX = 068Ch
  4573. Return: AX = capabilities (see #03520)
  4574.     DX = playback rate if fixed-frequency playback
  4575.     ---DIGPAK---
  4576.     BX:CX -> ASCIZ ID string
  4577. SeeAlso: AX=0689h,AX=068Dh
  4578.  
  4579. Bitfields for IBMSND driver capabilities:
  4580. Bit(s)    Description    (Table 03520)
  4581.  0    can play audio in background
  4582.  1    data is massaged for output device
  4583.  2    driver plays at fixed frequency, resampling input data to fit
  4584.  3    driver uses timer interrupt
  4585. ---DIGPAK---
  4586.  4    device supports timer sharing
  4587.  5    supports looped sounds and pending
  4588.  6    supports stereo panning
  4589.  7    supports 8-bit PCM stereo playback
  4590.  8    supports audio recording
  4591.  9    supports DMA bakcfilling
  4592. --------s-66068D-----------------------------
  4593. INT 66 - IBMSND driver, DIGPAK - REPORT CURRENT SAMPLE ADDRESS
  4594.     AX = 068Dh
  4595. Return: AX = current playback address
  4596. Desc:    determine what point in the audio data the playback has reached, for
  4597.       synchronization with video or animation effects
  4598. Notes:    this function applies to background playback only
  4599.     the reported address may be an approximation rather than the exact
  4600.       address
  4601. SeeAlso: AX=068Ch,AX=0691h
  4602. --------s-66068E-----------------------------
  4603. INT 66 - IBMSND driver, DIGPAK - SET CALLBACK ADDRESS
  4604.     AX = 068Eh
  4605.     BX:DX -> callback function
  4606.         0000h:0000h to disable callback
  4607.     DS = value to load into DS when calling the callback function
  4608. Desc:    specify the function to be called when playback of a sound effect is
  4609.       completed
  4610. Note:    the callback function will typically be called during a hardware
  4611.       interrupt, so all the usual precautions should be taken except for
  4612.       preserving registers
  4613. SeeAlso: AX=0691h
  4614. --------s-66068F-----------------------------
  4615. INT 66 - IBMSND driver, DIGPAK - STOP CURRENT SOUND
  4616.     AX = 068Fh
  4617. Desc:    cause any currently-playing sound effect to be terminated
  4618. SeeAlso: AX=0688h,AX=068Bh
  4619. --------s-660690-----------------------------
  4620. INT 66 - IBMSND driver, DIGPAK - "SetAudioHardware" - SET UP HARDWARE INFO
  4621.     AX = 0690h
  4622.     BX = IRQ
  4623.     CX = base address
  4624.     DX = other setup value (device-dependent???)
  4625. --------s-660691-----------------------------
  4626. INT 66 - IBMSND driver, DIGPAK - REPORT CALLBACK ADDRESS
  4627.     AX = 0691h
  4628. Return: AX:DX -> current callback function
  4629.     BX = original caller's DS register
  4630. Program: The IBMSND driver is part of John W. Ratcliff's
  4631.        The IBM Digitized Sound Package
  4632.     DIGPAK is a set of digitized sound drivers written by
  4633.       John W. Ratcliff, The Audio Solution, Inc.
  4634. SeeAlso: AX=068Eh
  4635. --------s-660693-----------------------------
  4636. INT 66 - DIGPAK - SET TIMER DIVISOR RATE
  4637.     AX = 0693h
  4638.     DX = rate
  4639. Program: DIGPAK is a set of digitized sound drivers written by
  4640.       John W. Ratcliff, The Audio Solution, Inc.
  4641. --------s-660694-----------------------------
  4642. INT 66 - DIGPAK - PLAY PREFORMATTED DATA
  4643.     AX = 0694h
  4644.     DS:SI -> Sound Data structure (see #03519)
  4645. Return: AX = status???
  4646. --------s-660695-----------------------------
  4647. INT 66 - DIGPAK - POST AUDIO PENDING
  4648.     AX = 0695h
  4649.     DS:SI -> Sound Data structure (***)
  4650. Return: AX = status
  4651.         0000h sound started playing
  4652.         0001h sound was posted as pending to play
  4653.         0002h sound effect already pending, this one not posted
  4654. SeeAlso: AX=0696h
  4655. --------s-660696-----------------------------
  4656. INT 66 - DIGPAK - GET AUDIO PENDING STATUS
  4657.     AX = 0696h
  4658. Return: AX = status
  4659.         0000h no sound is playing
  4660.         0001h sound playing, and a sound is pending
  4661.         0002h sound playing, no sound pending
  4662. SeeAlso: AX=0695h
  4663. --------s-660697-----------------------------
  4664. INT 66 - DIGPAK - SET STEREO PANNING
  4665.     AX = 0697h
  4666.     DX = panning position (0 = right, 127 = left)
  4667. Return: AX = status
  4668.         0000h command ignored (not supported)
  4669.         0001h panning set
  4670. --------s-660698-----------------------------
  4671. INT 66 - DIGPAK - SET PLAY MODE
  4672.     AX = 0698h
  4673.     DX = playback mode
  4674.         0000h 8-bit PCM
  4675.         0001h 8-bit stereo PCM
  4676.         0002h 16-bit PCM
  4677.         0003h 16-bit stereo PCM
  4678. Return: AX = status
  4679.         0000h command ignored
  4680.         0001h mode set
  4681. --------s-660699-----------------------------
  4682. INT 66 - DIGPAK - GET ADDRESSES
  4683.     AX = 0699h
  4684. Return: AX = pending address
  4685.     BX = semaphore address
  4686. --------s-66069A-----------------------------
  4687. INT 66 - DIGPAK - SET RECORD MODE
  4688.     AX = 069Ah
  4689.     DX = recording mode
  4690.         0000h turn audio recording on
  4691.         0001h turn audio recording off
  4692. Return: AX = status
  4693.         0000h command ignored
  4694.         0001h audio recording mode set
  4695. --------s-66069B-----------------------------
  4696. INT 66 - DIGPAK - STOP NEXT LOOP
  4697.     AX = 069Bh
  4698. --------s-66069C-----------------------------
  4699. INT 66 - DIGPAK - SET DMA BACKFILL MODE
  4700.     AX = 069Ch
  4701.     DX = mode
  4702.         0000h turn backfill mode on
  4703.         0001h turn backfill mode off
  4704. Return: AX = status
  4705.         0000h command ignored
  4706.         0001h backfill mode set
  4707. SeeAlso: AX=069Dh,AX=069Eh
  4708. --------s-66069D-----------------------------
  4709. INT 66 - DIGPAK - REPORT DMA COUNTER
  4710.     AX = 069Dh
  4711. Return: AX = DMA counter
  4712. SeeAlso: AX=069Eh
  4713. --------s-66069E-----------------------------
  4714. INT 66 - DIGPAK - VERIFY DMA BLOCK
  4715.     AX = 069Eh
  4716.     CX = length of buffer
  4717.     ES:BX -> buffer containing sound data
  4718. Return: AX = status
  4719.         0000h block crosses 64K bounadary
  4720.         0001h block is OK
  4721. SeeAlso: AX=069Dh
  4722. --------s-66069F-----------------------------
  4723. INT 66 - DIGPAK - SET PCM VOLUME
  4724.     AX = 069Fh
  4725.     BX = left channel volume (0-100)
  4726.     CX = right channel volume (0-100)
  4727. Return: AX =  status
  4728.         0000h command ignored
  4729.         0001h volume set
  4730. --------s-6606A0-----------------------------
  4731. INT 66 - DIGPAK - SET DPMI MODE
  4732.     AX = 06A0h
  4733.     DX = mode
  4734.         0000h 32-bit register addressing on
  4735.         0001h 32-bit register addressing off
  4736. SeeAlso: INT 31/AX=0400h
  4737. --------s-660700-----------------------------
  4738. INT 66 - MIDPAK - UNINSTALL
  4739.     AX = 0700h
  4740. Note:    this function should NOT be called by applications
  4741. Program: MIDPAK is a set of MIDI sound drivers developed by Miles Design
  4742.       Incorporated.
  4743. --------s-660701-----------------------------
  4744. INT 66 - IBM Digitized Sound Package MIDI driver - GET DIGITIZED SOUND CAPABIL
  4745.     AX = 0701h
  4746. Return: AX = digitized sound capabilities
  4747.         0000h if digitized sound driver (functions 06xxh) not available
  4748. InstallCheck:    test for the signature "MIDI" six bytes before the interrupt
  4749.       handler
  4750. Note:    also supported by MIDPAK, the successor to the Digitized Sound
  4751.       Package's MIDI driver
  4752. SeeAlso: AX=0688h
  4753. --------s-660702-----------------------------
  4754. INT 66 - MIDPAK - PLAY SEQUENCE
  4755.     AX = 0702h
  4756.     BX = Sequence number
  4757. Return: AX = status
  4758.         0000h Sequence is being played
  4759.         0001h Sequence not available
  4760. SeeAlso: AX=0703h,AX=0705h
  4761. --------s-660703-----------------------------
  4762. INT 66 - MIDPAK - SEGUE SEQUENCE
  4763.     AX = 0703h
  4764.     BX = sequence number
  4765.     CX = activation code (FFFFh is next trigger)
  4766. Return: ???
  4767. --------s-660704-----------------------------
  4768. INT 66 - MIDPAK - REGISTER XMIDI
  4769.     AX = 0704h
  4770.     CX:BX -> XMIDI sequence data
  4771.     DI:SI = length of XMIDI data
  4772. Return: AX = status
  4773.         0000h unable to register XMIDI data
  4774.         0001h XMIDI file registered resident
  4775.         0002h XMIDI file was registered to the application
  4776. --------s-660705-----------------------------
  4777. INT 66 - MIDPAK - STOP MIDI
  4778.     AX = 0705h
  4779. SeeAlso: AX=0702h,AX=0709h
  4780. --------s-660706-----------------------------
  4781. INT 66 O - MIDPAK - REMAP CHANNEL
  4782.     AX = 0706h
  4783.     BX = sequence
  4784.     CX = physical
  4785. --------s-660707-----------------------------
  4786. INT 66 - MIDPAK - REPORT TRIGGER EVENT COUNTER
  4787.     AX = 0707h
  4788. Return: AX = count of number of callbacks since last reset
  4789.     DX = ID
  4790. SeeAlso: AX=0708h,AX=0713h
  4791. --------s-660708-----------------------------
  4792. INT 66 - MIDPAK - RESET EVENT TRIGGER COUNTER
  4793.     AX = 0708h
  4794. SeeAlso: AX=0707h,AX=0713h
  4795. --------s-660709-----------------------------
  4796. INT 66 O - MIDPAK - MIDI SLEEP
  4797.     AX = 0709h
  4798. SeeAlso: AX=070Ah
  4799. --------s-66070A-----------------------------
  4800. INT 66 O - MIDPAK - MIDI AWAKE
  4801.     AX = 070Ah
  4802. SeeAlso: AX=0709h
  4803. --------s-66070B-----------------------------
  4804. INT 66 - MIDPAK - RESUME PLAYING
  4805.     AX = 070Bh
  4806. SeeAlso: AX=070Ch
  4807. --------s-66070C-----------------------------
  4808. INT 66 - MIDPAK - GET SEQUENCE STATUS
  4809.     AX = 070Ch
  4810. Return: AX = status
  4811.         0000h sequence stopped
  4812.         0001h sequence playing
  4813.         0002h sequence done
  4814. SeeAlso: AX=070Bh
  4815. --------s-66070D-----------------------------
  4816. INT 66 - MIDPAK - REGISTER XMIDI FILE
  4817.     AX = 070Dh
  4818.     CX:BX -> ASCII filename
  4819. SeeAlso: AX=0704h,AX=0710h
  4820. --------s-66070E-----------------------------
  4821. INT 66 - MIDPAK - GET RELATIVE VOLUME
  4822.     AX = 070Eh
  4823. Return: AX = current volume
  4824. SeeAlso: AX=070Fh
  4825. --------s-66070F-----------------------------
  4826. INT 66 - MIDPAK - SET RELATIVE VOLUME
  4827.     AX = 070Fh
  4828.     BX = new volume
  4829.     CX = time
  4830. SeeAlso: AX=070Eh
  4831. --------s-660710-----------------------------
  4832. INT 66 - MIDPAK - LOAD MIDPAK DRIVER
  4833.     AX = 0710h
  4834.     BX = segment of .ADV driver
  4835.     CX = 0000h (offset must be zero)
  4836.     DX:SI -> .AD driver
  4837. SeeAlso: AX=070Dh
  4838. --------s-660711-----------------------------
  4839. INT 66 - MIDPAK - POLL MIDPAK
  4840.     AX = 0711h
  4841. Return: AX = ???
  4842.     ???
  4843. SeeAlso: AX=0712h
  4844. --------s-660712-----------------------------
  4845. INT 66 - MIDPAK - GET MIDI CLOCK
  4846.     AX = 0712h
  4847. Return: AX:DX = clock counter
  4848.     CX:BX = clock address
  4849. SeeAlso: AX=0711h,AX=0713h
  4850. --------s-660713-----------------------------
  4851. INT 66 - MIDPAK - GET TRIGGER COUNT ADDRESS
  4852.     AX = 0713h
  4853. Return: AX:DX -> trigger counter address
  4854. SeeAlso: AX=0707h,AX=0712h,AX=0714h
  4855. --------s-660714-----------------------------
  4856. INT 66 - MIDPAK - GET EVENT ID ADDRESS
  4857.     AX = 0714h
  4858. Return: AX:DX -> event ID
  4859. SeeAlso: AX=0713h,AX=0716h
  4860. --------s-660716-----------------------------
  4861. INT 66 - MIDPAK - REPORT SEQUENCE NUMBER
  4862.     AX = 0716h
  4863. Return: AX = current sequence number
  4864. SeeAlso: AX=0702h
  4865. Program: MIDPAK is a set of MIDI sound drivers developed by Miles Design
  4866.       Incorporated.
  4867. --------n-6610-------------------------------
  4868. INT 66 - PenDOS - TDMOUSE.EXE - GET ???
  4869.     AH = 10h
  4870. Return: CF clear
  4871.     AX = 0000h
  4872.     BX = ??? (0012h)
  4873.     DX:CX -> TDMOUSE INT 33 handler (IRET to hide mouse from other apps)
  4874. Program: TDMOUSE is a PenDOS hardware driver which allows a mouse to emulate
  4875.       a touchpad; PenDOS is a set of programs by Communication Intelligence
  4876.       Corporation which makes applications pen-aware
  4877. --------n-6611-------------------------------
  4878. INT 66 - PenDOS - TDMOUSE.EXE - SET ??? HANDLER
  4879.     AH = 11h
  4880.     DX:BX -> new handler for ???
  4881. Return: CF clear
  4882.     AX = 0000h
  4883.     DX:BX -> old handler for ??? (points at RETF by default)
  4884. --------n-6612-------------------------------
  4885. INT 66 - PenDOS - TDMOUSE.EXE - INITIALIZE
  4886.     AH = 12h
  4887. Return: CF clear
  4888.     AX = 0000h
  4889. Note:    this function calls the old mouse handler with functions 0000h, 0002h,
  4890.       0007h, 0008h, 000Fh, 0004h, and 000Ch (in that order)
  4891. SeeAlso: AH=13h
  4892. --------n-6613-------------------------------
  4893. INT 66 - PenDOS - TDMOUSE.EXE - SHUTDOWN???
  4894.     AH = 13h
  4895. Return: CF clear
  4896.     other register as returned by INT 33/AX=0000h
  4897. SeeAlso: AH=12h
  4898. --------n-6614-------------------------------
  4899. INT 66 - PenDOS - TDMOUSE.EXE - ???
  4900.     AH = 14h
  4901.     BX = ???
  4902.     CX = ???
  4903. Return: CF clear
  4904.     AX = 0000h
  4905. --------n-6615-------------------------------
  4906. INT 66 - PenDOS - TDMOUSE.EXE - SET ??? HANDLER
  4907.     AH = 15h
  4908.     DX:BX -> new handler for ???
  4909. Return: CF clear
  4910.     AX = 0000h
  4911.     DX:BX -> old handler (points at RETF by default)
  4912. --------n-6616-------------------------------
  4913. INT 66 - PenDOS - TDMOUSE.EXE - UNUSED FUNCTIONS
  4914.     AH = 16h to 1Fh
  4915. Return: CF set
  4916. Program: TDMOUSE is a PenDOS hardware driver which allows a mouse to emulate
  4917.       a touchpad; PenDOS is a set of programs by Communication Intelligence
  4918.       Corporation which makes applications pen-aware
  4919. --------n-6621-------------------------------
  4920. INT 66 - PenDOS - PINK - ???
  4921.     AH = 21h
  4922. Return: CF clear if successful
  4923.     CF set on error
  4924. Note:    this function sets ??? flag or counter (also set by AH=2Fh) to FFFFh
  4925. --------n-6622-------------------------------
  4926. INT 66 - PenDOS - PINK - ???
  4927.     AH = 22h
  4928.     DX:BX -> ???
  4929.     CL = ???
  4930. Return: CF clear if successful
  4931.     CF set on error
  4932.     ???
  4933. SeeAlso: AH=24h
  4934. --------n-6623-------------------------------
  4935. INT 66 - PenDOS - PINK - ???
  4936.     AH = 23h
  4937.     ???
  4938. Return: CF clear if successful
  4939.     CF set on error
  4940.     ???
  4941. --------n-6624-------------------------------
  4942. INT 66 - PenDOS - PINK - ???
  4943.     AH = 24h
  4944.     DX:BX -> ???
  4945.     CL = ???
  4946. Return: CF clear if successful
  4947.     CF set on error
  4948.     ???
  4949. SeeAlso: AH=22h
  4950. --------n-6625-------------------------------
  4951. INT 66 - PenDOS - PINK - ???
  4952.     AH = 25h
  4953.     CL = ??? (NOP if 00h)
  4954.     ???
  4955. Return: CF clear if successful
  4956.     CF set on error
  4957.     ???
  4958. --------n-6627-------------------------------
  4959. INT 66 - PenDOS - PINK - ???
  4960.     AH = 27h
  4961.     BL = ???
  4962.     BH = ???
  4963.     CL = ??? (0-3)
  4964.     DL = ??? (> BL)
  4965.     DH = ??? (> BH)
  4966. Return: ???
  4967. --------n-6628-------------------------------
  4968. INT 66 - PenDOS - PINK - ???
  4969.     AH = 28h
  4970.     ???
  4971. Return: CF clear if successful
  4972.     CF set on error
  4973.     ???
  4974. Note:    this function sets ??? flag or counter (also set by AH=2Fh) to FFFFh
  4975. --------n-6629-------------------------------
  4976. INT 66 - PenDOS - PINK - ???
  4977.     AH = 29h
  4978.     ???
  4979. Return: ???
  4980. Note:    this function sets ??? flag or counter (also set by AH=2Fh) to FFFFh
  4981. --------n-662A-------------------------------
  4982. INT 66 - PenDOS - PINK - ???
  4983.     AH = 2Ah
  4984.     DL = ??? (nonzero)
  4985.     DH = ??? (nonzero)
  4986. Return: CF clear if successful
  4987.     CF set on error
  4988.     ???
  4989. --------n-662B-------------------------------
  4990. INT 66 - PenDOS - PINK - ???
  4991.     AH = 2Bh
  4992.     ???
  4993. Return: CF clear if successful
  4994.     CF set on error
  4995.     ???
  4996. --------n-662F-------------------------------
  4997. INT 66 - PenDOS - PINK - INITIALIZE
  4998.     AH = 2Fh
  4999.     ???
  5000. Return: AX = status
  5001.         0000h failed
  5002.         FFFFh successful
  5003.     ???
  5004. Note:    this function sets ??? flag or counter to FFFFh and hooks INT 1Ch
  5005. --------F-663345-----------------------------
  5006. INT 66 - BitFax Scheduler - REMOVE TSR FROM MEMORY
  5007.     AX = 3345h
  5008. Return: AX = FFFFh error removing TSR
  5009. InstallCheck:    test for the signature "BitFax Scheduler" beginning two bytes
  5010.       past the interrupt handler
  5011. SeeAlso: AH=04h,INT 2F/AH=2Ah,INT 2F/AX=CB00h
  5012. Index:    installation check;BitFax Scheduler
  5013. --------n-6640-------------------------------
  5014. INT 66 - PenDOS - PKEYUS - GET VERSION
  5015.     AH = 40h
  5016. Return: CF clear
  5017.     AX = 0000h
  5018.     BH = major version (02h for version bundled with IBM DOS 6.1)
  5019.     BL = minor version (00h for version bundled with IBM DOS 6.1)
  5020.     DL = ??? (4Eh)
  5021.     DH = ??? (0Eh)
  5022. --------n-6641-------------------------------
  5023. INT 66 - PenDOS - PKEYUS - SET ???
  5024.     AH = 41h
  5025.     BX = ???
  5026.     CL = ??? (08h-20h)
  5027.     DL = screen column??? (<= 50h)
  5028.     DH = screen row???  (<= 3Ch)
  5029. Return: AX = status (0000h successful, 0001h error)
  5030. Note:    this function also sets an internal flag
  5031. SeeAlso: AH=42h,AH=43h
  5032. --------n-6642-------------------------------
  5033. INT 66 - PenDOS - PKEYUS - ???
  5034.     AH = 42h
  5035. Return: CF clear
  5036.     AX = 0000h
  5037. Note:    this function also clears the flag set by AH=41h
  5038. SeeAlso: AH=41h
  5039. --------n-6643-------------------------------
  5040. INT 66 - PenDOS - PKEYUS - ???
  5041.     AH = 43h
  5042.     BX = ???
  5043.     DX = ???
  5044. Return: AX = status
  5045.         0000h if AH=41h flag set
  5046.         else
  5047.         AH = ???
  5048.         AL = ???
  5049.         BX = ???
  5050.         DX = ???
  5051. SeeAlso: AH=41h
  5052. --------n-6644-------------------------------
  5053. INT 66 - PenDOS - PKEYUS - UNUSED FUNCTIONS
  5054.     AH = 44h to 4Fh
  5055. Return: CF set
  5056. --------n-6650-------------------------------
  5057. INT 66 - PenDOS - PMOUSE - SET ???
  5058.     AH = 50h
  5059.     BX = ???
  5060.     CH = ???
  5061.     DX = ???
  5062. Return: CF clear
  5063.     AX = 0000h
  5064. --------n-6651-------------------------------
  5065. INT 66 - PenDOS - PMOUSE - NOP
  5066.     AH = 51h
  5067. Return: CF set
  5068. --------n-6652-------------------------------
  5069. INT 66 - PenDOS - PMOUSE - ???
  5070.     AH = 52h
  5071.     BX = ???
  5072.     CL = ???
  5073.     DX = ???
  5074. Return: ???
  5075. --------n-6653-------------------------------
  5076. INT 66 - PenDOS - PMOUSE - UNUSED FUNCTIONS
  5077.     AH = 53h to 57h
  5078. Return: CF set
  5079. --------n-66---------------------------------
  5080. INT 66 - PenDOS - PMOUSE - ALTERNATE API
  5081.     AH = function (58h-5Fh)
  5082. Note:    these functions exactly duplicate AH=50h-57h
  5083. --------U-66AA02-----------------------------
  5084. INT 66 - HelpTSR v2.10 - INSTALLATION CHECK
  5085.     AX = AA02h
  5086. Return: ES:DI -> 7 byte signature "HelpTSR" if resident
  5087. Program: HelpTSR is a resident viewer by David Jurgens for HelpPC
  5088. --------n-66C5-------------------------------
  5089. INT 66 - PenDOS - VLOAD - API
  5090.     AH = C5h
  5091.     ???
  5092. Return: ???
  5093. --------t-66FFFBBXFFFB-----------------------
  5094. INT 66 - MicroHelp Stay-Res Plus - ???
  5095.     AX = FFFBh
  5096.     BX = FFFBh
  5097.     ???
  5098. Return: ???
  5099. SeeAlso: AX=FFFEh,INT 2D"AMIS"
  5100. --------t-66FFFEBXFFFE-----------------------
  5101. INT 66 - MicroHelp Stay-Res/Stay-Res Plus - UNINSTALL
  5102.     AX = FFFEh
  5103.     BX = FFFEh
  5104. Return: only if unsuccessful
  5105. InstallCheck:    test whether the interrupt handler begins with the bytes
  5106.       FBh 9Ch or 9Ch FAh, and the program name (not case-sensitive) appears
  5107.       at offset 0005h (older versions) or the offset returned by
  5108.       AX=FFFFh/BX=FFF0h in the interrupt handler segment
  5109. Note:    Programs which use Stay-Res include ThesPlus (program name "THESPLUS")
  5110.       and Personal Calendar (program name "CAL") by Paul Mun~oz-Colman.
  5111. SeeAlso: AX=FFFBh,AX=FFFFh,INT 2D"AMIS"
  5112. Index:    installation check;MicroHelp Stay-Res|installation check;ThesPlus
  5113. Index:    installation check;Personal Calendar|installation check;CAL
  5114. --------t-66FFFFBXFFF0-----------------------
  5115. INT 66 - MicroHelp Stay-Res Plus - FIND PROGRAM NAME
  5116.     AX = FFFFh
  5117.     BX = FFF0h
  5118. Return: DI = offset of program name in interrupt handler segment
  5119. SeeAlso: AX=FFFBh,AX=FFFEh,INT 2D"AMIS"
  5120. --------d-67---------------------------------
  5121. INT 67 - Adaptec controllers - DRIVE 1 DATA
  5122. Desc:    this vector stores the last four bytes of the parameter table for
  5123.       hard disk 1
  5124. SeeAlso: INT 64"Adaptec",INT 65"Adaptec",INT 66"Adaptec"
  5125. --------b-67---------------------------------
  5126. INT 67 - TI Professional PC - SYSTEM DATA (NOT A VECTOR!)
  5127. Desc:    this vector contains the TI Pro's system configuration words
  5128.       (see #03521)
  5129. SeeAlso: INT 66"TI Professional PC"
  5130.  
  5131. Bitfields for TI Professional PC System Configuration doubleword:
  5132. Bit(s)    Description    (Table 03521)
  5133.  0    8087 present
  5134.  31-1    reserved (0)
  5135. --------d-67---------------------------------
  5136. INT 67 - Pdisk by Scott Garfinkle - Overwritten for Hard Drive information
  5137. SeeAlso: INT 64"Pdisk",INT 66"Pdisk"
  5138. --------I-67---------------------------------
  5139. INT 67 - Sangoma CCPOP 3270 resident module
  5140. SeeAlso: INT 61"Sangoma",INT 68"Sangoma"
  5141. --------U-67---------------------------------
  5142. INT 67 - CUCKOO.COM - INSTALLATION CHECK
  5143. Program: CUCKOO is a resident on-screen clock with optional hourly chime or
  5144.       cuckoo by an unknown author with revisions by Thomas A. Lundin
  5145. Note:    this is not a vector; when loaded for the first time, CUCKOO.COM uses
  5146.       the last unused (0000h:0000h) vector in the range 60h-67h to store
  5147.       the signature value 434Ch:4F4Bh ('CLOK')
  5148. ----------67---------------------------------
  5149. INT 67 - PC-DRAFT - KEYBOARD DRIVER
  5150.     ???
  5151. Return: ???
  5152. Program: PC-DRAFT is a powerful CAD environment by rhv.
  5153. SeeAlso: INT 62"PC-DRAFT",INT 64"PC-DRAFT",INT 65"PC-DRAFT",INT 66"PC-DRAFT"
  5154. --------N-6700-------------------------------
  5155. INT 67 - PC-NET, Alloy NTNX - LOCK SEMAPHORE AND WAIT
  5156.     AH = 00h
  5157.     DS:DX -> ASCIZ semaphore name (max 64 bytes)
  5158. Return: AL = status (see #03522)
  5159.     AH = semaphore owner if status=02h
  5160. SeeAlso: AH=01h,AH=02h"PC-NET",INT 7F/AH=00h
  5161.  
  5162. (Table 03522)
  5163. Values for PC-NET semaphore function status:
  5164.  00h    successful
  5165.  01h    invalid function
  5166.  02h    semaphore already locked
  5167.  03h    unable to lock semaphore
  5168.  04h    semaphore space exhausted
  5169. --------N-6701-------------------------------
  5170. INT 67 - PC-NET, Alloy NTNX - LOCK SEMAPHORE
  5171.     AH = 01h
  5172.     DS:DX -> ASCIZ semaphore name (max 64 bytes)
  5173. Return: AL = status (see #03522)
  5174.     AH = semaphore owner if status=02h
  5175. SeeAlso: AH=00h,AH=02h"PC-NET",INT 7F/AH=01h"Alloy"
  5176. --------N-6702-------------------------------
  5177. INT 67 - PC-NET, Alloy NTNX - UNLOCK SEMAPHORE
  5178.     AH = 02h
  5179.     DS:DX -> ASCIZ semaphore name (max 64 bytes)
  5180. Return: AL = status (see #03522)
  5181.     AH = semaphore owner if status=02h
  5182. SeeAlso: AH=00h,AH=01h"PC-NET",INT 7F/AH=02h
  5183. --------m-671E-------------------------------
  5184. INT 67 U - Qualitas 386MAX v7.00 - MEMLIMIT - INSTALLATION CHECK
  5185.     AH = 1Eh
  5186. Return: AH = 00h if installed
  5187.         AL destroyed
  5188.         ES:DI -> ASCII signature "MemLimit"
  5189. SeeAlso: AH=1Fh,INT 21/AX=4402h"386MAX"
  5190. --------m-671F-------------------------------
  5191. INT 67 U - Qualitas 386MAX v7.00 - MEMLIMIT - API
  5192.     AH = 1Fh
  5193.     DS:SI -> request packet (see #03523)
  5194. Return: AH = status (00h successful, 84h invalid function code, etc.)
  5195. SeeAlso: AH=1Eh
  5196.  
  5197. Format of 386MAX MEMLIMIT request packet:
  5198. Offset    Size    Description    (Table 03523)
  5199.  00h    WORD    function code (00h-0Fh)
  5200.  02h    WORD    return code (see #03524)
  5201.  04h  4 BYTEs    ???
  5202.  08h    WORD    ???
  5203.     ???
  5204.  
  5205. (Table 03524)
  5206. Values for 386MAX MEMLIMIT return code:
  5207.  00h    unknown request
  5208.  01h    invalid parameter for VCPI limit
  5209.  02h    VCPI limit set
  5210.  03h    invalid parameter for EMS limit
  5211.  04h    EMS limit set
  5212.  05h    DPMI disabled
  5213.  06h    XMS disabled
  5214.  07h    XMS limit set
  5215.  08h    unable to uninstall
  5216.  09h    unloaded
  5217. --------m-672763CL01-------------------------
  5218. INT 67 - VIDEMS.SYS v1.31+ - INSTALLATION CHECK
  5219.     AX = 2763h
  5220.     CL = 01h
  5221.     BX = signature AAFFh
  5222. Return: AH = 00h if VIDEMS is installed
  5223.         CH = 00h if optimization for 80286 is used, 01h otherwise
  5224.         CL = internal revision number (typically 00h to 03h)
  5225.         DX = driver version (DH=major, DL=minor; not a BCD!)
  5226.     AH = 84h if not installed but EMS manager is present
  5227. Program: VIDEMS is an expanded memory manager from Conea Software Corp. It
  5228.      converts video adapter RAM to LIM 3.2 EMS.
  5229. SeeAlso: AX=2763h/CL=02h,AX=2763h/CL=03h
  5230. --------m-672763CL02-------------------------
  5231. INT 67 - VIDEMS.SYS v1.31+ - FLUSH EMS TO VIDEO RAM
  5232.     AX = 2763h
  5233.     CL = 02h
  5234.     BX = signature AAFFh
  5235. Return: AH = 00h if successful
  5236. Notes:    This call is normally used by Conea products only.
  5237. SeeAlso: AX=2763h/CL=01h,AX=2763h/CL=03h
  5238. --------m-672763CL03-------------------------
  5239. INT 67 - VIDEMS.SYS v1.31+ - RELOAD EMS FROM VIDEO RAM
  5240.     AX = 2763h
  5241.     CL = 03h
  5242.     BX = signature AAFFh
  5243. Return: AH = 00h if successful
  5244. Notes:    This call is normally used by Conea products only.
  5245. SeeAlso: AX=2763h/CL=01h,AX=2763h/CL=03h
  5246. --------m-672763CL04-------------------------
  5247. INT 67 - VIDEMS.SYS v1.31+ - RETURN HIDDEN BLOCK SIZE
  5248.     AX = 2763h
  5249.     CL = 04h
  5250.     BX = signature AAFFh
  5251. Return: AH = 00h if successful
  5252.         DX = block size in kilobytes
  5253. Desc:    Returns the amount of EMS which can be safely used at any time, and
  5254.       can't be destroyed by writing anything to the B800:0000 buffer.
  5255. Note:    this function normally returns 184K, while the driver provides up to
  5256.       240K of EMS.
  5257. SeeAlso: AX=2763h/CL=01h,AX=2763h/CL=02h
  5258. --------m-672763CL05-------------------------
  5259. INT 67 - VIDEMS.SYS v1.31+ - RETURN PHYSICAL PAGE SIZE
  5260.     AX = 2763h
  5261.     CL = 05h
  5262.     BX = signature AAFFh
  5263. Return: AH = 00h
  5264.     DX = size in bytes
  5265. Desc:    Used by Conea products to determine if addressing mode has changed.
  5266.       Normally, all VIDEMS versions beginning from 1.15 use 4K "physical"
  5267.       pages.
  5268. Notes:    this function will probably become raw page size in future releases of
  5269.       VIDEMS, which    will support the LIM 4.0 standard.
  5270. SeeAlso: AX=2763h/CL=01h,AX=2763h/CL=02h
  5271. --------m-672763CL06-------------------------
  5272. INT 67 - VIDEMS.SYS v1.50+ - RETURN VIDEO RAM SIZE
  5273.     AX = 2763h
  5274.     CL = 06h
  5275.     BX = signature AAFFh
  5276. Return: AH = 00h
  5277.     DX = total amount of video RAM
  5278. Desc:    beginning with version 1.50, VIDEMS can use more adapter memory on
  5279.       some chipsets, and is no longer limited to the first 240K.
  5280. Notes:    this call is not officially documented, and Conea programmers use it
  5281.       mainly for debugging purposes.
  5282. --------u-672833-----------------------------
  5283. INT 67 - Q87 v4+ - PREPARE TO UNLOAD AND GET XMS HANDLE FOR Q87 MEMORY
  5284.     AX = 2833h
  5285.     EAX = 29482833h (entire EAX value required)
  5286. Return: EAX = XMS handle for memory allocated when Q87 was installed
  5287.     EBX = status
  5288.         00000000h Q87 is in demo mode (countdown running);
  5289.               Q87 remains active
  5290.         00000001h Q87 is in registered mode; memory manager's IDT, GDT,
  5291.               and optionally CR0 (if BL <> 5Fh on entry) have
  5292.               been restored
  5293.         00000002h Q87 is in demo mode (demo time has expired);
  5294.               Q87 remains active
  5295. Note:    this call is used by UNLOAD87 to release the memory used by Q87
  5296. BUG:    v4.00-v4.03 will hang on most machines when run under bare DOS with
  5297.       no memory manager, because neither Q87 nor UNLOAD87 checks whether
  5298.       there is a valid INT 67 handler before performing an installation
  5299.       check via INT 67
  5300. SeeAlso: AX=4321h,INT 21/AX=4321h/BX=0000h
  5301. --------m-673F--CX5145-----------------------
  5302. INT 67 U - QEMM-386 v4.23+ - INSTALLATION CHECK
  5303.     AH = 3Fh
  5304.     CX = 5145h ("QE")
  5305.     DX = 4D4Dh ("MM")
  5306. Return: AH = 00h if installed
  5307.         ES:DI -> QEMM API entry point (see #03525,#03528,#03640)
  5308. Notes:    if no other program has hooked INT 67, an alternate installation
  5309.       check is to test for the string
  5310.       "QUARTERDECK EXPANDED MEMORY MANAGER 386" at offset 14h in the INT 67
  5311.       handler's segment; the word at offset 12h contains the offset in
  5312.       the handler's segment of the API entry point
  5313.     although this function is still undocumented, Quarterdeck has recently
  5314.       documented two alternate methods for determining the QEMM API entry
  5315.       point, as well as several of the API functions
  5316.     MICEMM (Micronics Expanded Memory Manager) versions 2.0C and 4D support
  5317.       the alternate QEMM installation check and entry point functions 00h,
  5318.       02h, and 03h; version 4D only provides the signature string if the
  5319.       commandline argument "DV" is provided
  5320.     386MAX v6.01 responds to this call, but DESQview 2.42 does not
  5321.       recognize the returned entry point as providing QEMM's capabilities
  5322.       because a) only functions 0Ch (different from QEMM 0Ch) and
  5323.             1000h-1009h are supported,
  5324.           b) status is returned as for EMS functions, not QEMM funcs
  5325.           c) the protected-mode entry point returned by function 1000h
  5326.             only supports functions 0Ch, 1004h, 1005h, and 100Ah
  5327.     the string check mentioned above is not supported by 386MAX
  5328. SeeAlso: AX=5BF0h,AH=DDh,AX=FFA5h,INT 15/AX=11DEh,INT 21/AX=4402h/SF=01h
  5329. SeeAlso: INT 21/AX=4402h"QEMM",INT 21/AX=4402h"386MAX",INT 2F/AX=D201h/BX=5145h
  5330.  
  5331. (Table 03525)
  5332. Values for calling QEMM "QPI_GetStatus" function:
  5333.     AH = 00h get QEMM state
  5334. Return: CF clear
  5335.     AL = QEMM state
  5336.         bit 0 set if QEMM turned OFF
  5337.         bit 1 set if in "Auto" mode
  5338. Note:    this function is officially documented
  5339. SeeAlso: #03526,#03527,#03528,#03640
  5340.  
  5341. (Table 03526)
  5342. Values for calling QEMM "QPI_SetStatus" function:
  5343.     AH = 01h set QEMM state
  5344.     AL = new state
  5345.         bit 0 set: place QEMM in OFF state
  5346. Return: CF clear if successful
  5347.     CF set on error
  5348. Note:    this function is officially documented
  5349. SeeAlso: #03525
  5350.  
  5351. (Table 03527)
  5352. Values for calling QEMM QPI function 02h:
  5353.     AH = 02h get ???
  5354. Return: CF clear
  5355.     AX = segment of ??? data structure
  5356.     Data Structure
  5357.     Offset    Size    Description
  5358.      00h    DWORD    page table entry for ???
  5359.         ???
  5360. SeeAlso: #03528
  5361.  
  5362. (Table 03528)
  5363. Values for calling QEMM "QPI_GetVersion" function:
  5364.     AH = 03h get QEMM version
  5365. Return: CF clear
  5366.     AX = BX = version in BCD
  5367. Notes:    this function is officially documented.     The most recent official docs
  5368.       state that the version is returned in both AX and BX; older
  5369.       documentation only mentions BX
  5370.     MICEMM returns AX=0001h, BX unchanged
  5371. SeeAlso: #03525,#03529
  5372.  
  5373. (Table 03529)
  5374. Values for calling QEMM QPI function 04h:
  5375.     AH = 04h allocate 4K page and set AUTO/ON mode
  5376. Return: CF clear if successful
  5377.         DX = page number of a 4K page
  5378.     CF set if unable to allocate page
  5379. Note:    QEMM mode unchanged if not AUTO/OFF
  5380. SeeAlso: #03530
  5381.  
  5382. (Table 03530)
  5383. Values for calling QEMM QPI function 05h:
  5384.     AH = 05h free 4K page and turn QEMM off
  5385.     DX = page number returned by function 04h
  5386. Return: CF clear
  5387. Note:    QEMM mode unchanged if not AUTO/ON
  5388. SeeAlso: #03529,#03531
  5389.  
  5390. (Table 03531)
  5391. Values for calling QEMM QPI function 06h:
  5392.     AH = 06h make new mapping context???
  5393.     DX = page number of 4K page to hold page table
  5394. Return: CF clear
  5395. Note:    copies page table into given page and then sets ??? page table entry
  5396.       to point at copy
  5397. SeeAlso: #03532,#03533
  5398.  
  5399. (Table 03532)
  5400. Values for calling QEMM QPI function 07h:
  5401.     AH = 07h get mapping context
  5402. Return: CF clear
  5403.     DX = page number of page table for current mapping context
  5404. SeeAlso: #03528,#03531,#03533
  5405.  
  5406. (Table 03533)
  5407. Values for calling QEMM QPI function 08h:
  5408.     AH = 08h set mapping context???
  5409.     DX = linear page number of page table
  5410. Return: CF clear
  5411. SeeAlso: #03528,#03531,#03532,#03534,#03536
  5412.  
  5413. (Table 03534)
  5414. Values for calling QEMM QPI function 09h:
  5415.     AH = 09h get linear page number for page table entry
  5416.     CX = page table index
  5417. Return: CF clear
  5418.     DX = linear page number
  5419. SeeAlso: #03535
  5420.  
  5421. (Table 03535)
  5422. Values for calling QEMM QPI function 0Ah:
  5423.     AH = 0Ah set linear page number for page table entry
  5424.     CX = page table index
  5425.     DX = linear page number
  5426. Return: CF clear
  5427. SeeAlso: #03534
  5428.  
  5429. (Table 03536)
  5430. Values for calling QEMM QPI function 0Bh:
  5431.     AH = 0Bh map 4K pages
  5432.     BX = number of pages
  5433.     CX = first page number (must be 0100h to allocate HMA)
  5434.     DX = EMS handle (memory belonging to EMS handle will be mapped
  5435.           into the address space beginning with the first page
  5436.           allocated to the handle)
  5437. Return: AH = 00h
  5438. SeeAlso: #03533,#03537
  5439.  
  5440. (Table 03537)
  5441. Values for calling QEMM QPI function 0Ch:
  5442.     AH = 0Ch get available memory
  5443. Return: CF clear
  5444.     BX = 0001h
  5445.     CX = total 4K pages???
  5446.     DX = number of 4K pages free
  5447. SeeAlso: #03536,#03538
  5448.  
  5449. (Table 03538)
  5450. Values for calling QEMM QPI function 0Dh:
  5451.     AH = 0Dh CRT controller I/O port trapping
  5452.     AL = mode
  5453.         00h only trap on I/O ports 03C0h-03C5h, 03C7h, 03CAh-03CFh
  5454.         01h trap on ports 03B4h, 03B5h, 03B8h, 03C6h, 03C8h, 03C9h,
  5455.           03D4h, and 03D5h
  5456.         02h only trap on I/O ports 03C6h, 03C8h, and 03C9h
  5457. Return: CF clear
  5458.  
  5459. (Table 03539)
  5460. Values for calling QEMM QPI function 0Eh:
  5461.     AH = 0Eh set cursor virtualization callbacks
  5462.     DS:BX -> FAR routine for getting hardware cursor address
  5463.     ES:DX -> FAR routine for setting hardware cursor address
  5464. Return: CF clear
  5465. Note:    both callbacks are invoked with CL indicating which
  5466.       CRT controller register to access (0Eh for high
  5467.       byte of cursor address, 0Fh for low byte)
  5468.     the DS:BX callback should return BX=cursor address;
  5469.       ES:DX is called with BL or BH (depending on CL)
  5470.       set to the appropriate half of the cursor's address
  5471.  
  5472. (Table 03540)
  5473. Values for calling QEMM QPI function 0Fh:
  5474.     AH = 0Fh unmap 4K pages
  5475.     CX = first page number
  5476.     DX = number of pages
  5477. Return: CF clear
  5478.     AL = 00h/01h if ???
  5479. Note:    if CX=0100h and DX=0010h, the HMA is remapped to
  5480.       simulate a disabled A20
  5481.  
  5482. (Table 03541)
  5483. Values for calling QEMM QPI function 1000h:
  5484.     AX = 1000h get protected-mode interface
  5485.     DS:SI -> 16-byte buffer for two GDT entries
  5486.     ES:DI -> buffer for 4K page table
  5487. Return: CF clear
  5488.     EAX = offset of protected-mode API entry point
  5489.     DS:SI buffer filled with two GDT descriptors
  5490.         first is QEMM code segment, second is data???
  5491.     ES:DI buffer filled with 4K page table
  5492.     DI points to first unused page table entry
  5493. SeeAlso: INT 67/AX=DE01h
  5494.  
  5495. (Table 03542)
  5496. Values for calling QEMM QPI function 1001h:
  5497.     AX = 1001h get CPU debug registers
  5498.     ES:DI -> buffer for debug registers (8 DWORDs)
  5499. Return: CF clear
  5500.     BL = INT01 handling (see #03543)
  5501.     ES:DI buffer filled
  5502.  
  5503. (Table 03543)
  5504. Values for calling QEMM QPI function 1002h:
  5505.     AX = 1002h set CPU debug registers
  5506.     BL = INT01 handling
  5507.         00h     reflect all debugging exceptions as V86-mode INT 01's
  5508.         else convert debugging exceptions other than single-step
  5509.           into V86-mode INT 03's, single-step to INT 01's
  5510.     ES:DI -> buffer containing debug registers (8 DWORDs)
  5511. Return: CF clear
  5512. Notes:    identical to INT 67/AX=DE09h if BL=01h
  5513.     the INT01 handling flag is set to 01h by the general-protection
  5514.       violation handler for certain privileged instructions
  5515. SeeAlso: #03542
  5516.  
  5517. (Table 03544)
  5518. Values for calling QEMM QPI function 1003h:
  5519.     AX = 1003h get machine status word CR0
  5520. Return: CF clear
  5521.     EAX = contents of CR0
  5522. SeeAlso: INT 67/AX=DE07h
  5523.  
  5524. (Table 03545)
  5525. Values for calling QEMM QPI function 1004h:
  5526.     AX = 1004h allocate a 4K page
  5527. Return: CF clear if successful
  5528.         EDX = linear address of allocated page
  5529.     CF set on error
  5530. SeeAlso: INT 67/AX=DE04h
  5531.  
  5532. (Table 03546)
  5533. Values for calling QEMM QPI function 1005h:
  5534.     AX = 1005h free 4K page
  5535.     EDX = linear address of page to free
  5536. Return: CF clear
  5537. SeeAlso: INT 67/AX=DE05h
  5538.  
  5539. (Table 03547)
  5540. Values for calling QEMM QPI function 1006h:
  5541.     AX = 1006h NOP
  5542. Return: CF set
  5543.  
  5544. (Table 03548)
  5545. Values for calling QEMM QPI function 1007h:
  5546.     AX = 1007h get maximum physical memory address
  5547. Return: CF clear
  5548.     EDX = physical address of highest 4K memory page
  5549. SeeAlso: INT 67/AX=DE02h
  5550.  
  5551. (Table 03549)
  5552. Values for calling QEMM QPI function 1008h:
  5553.     AX = 1008h get physical address of page in first megabyte
  5554.     CX = page number (linear address shifted right 12 bits)
  5555. Return: CF clear
  5556.     EDX = linear address of page
  5557. SeeAlso: #03548,#03624,#03625
  5558.  
  5559. (Table 03550)
  5560. Values for calling QEMM QPI function 1009h:
  5561.     AX = 1009h switch to protected mode
  5562.     ESI = linear address in first megabyte of system reg values
  5563.           (see INT 67/AX=DE0Ch)
  5564.     interrupts disabled
  5565. Return: interrupts disabled
  5566.     GDTR, IDTR, LDTR, TR loaded
  5567.     SS:ESP must have at least 16 bytes space, and the
  5568.           entry point is required to set up a new stack
  5569.           before enabling interrupts
  5570.     EAX, ESI, DS, ES, FS, GS destroyed
  5571.  
  5572. (Table 03551)
  5573. Values for calling QEMM QPI function 100Ah:
  5574.     AX = 100Ah switch back to virtual-86 mode
  5575.     DS = selector for data segment from function 1000h
  5576.     SS:ESP in first megabyte of linear memory
  5577.     interrupts disabled
  5578.     STACK:    QWORD  return address from FAR call to 32-bit segment
  5579.         DWORD  EIP
  5580.         DWORD  CS
  5581.         DWORD  reserved for EFLAGS
  5582.         DWORD  ESP
  5583.         DWORD  SS
  5584.         DWORD  ES
  5585.         DWORD  DS
  5586.         DWORD  FS
  5587.         DWORD  GS
  5588.     will switch to virtual86 mode with interrupts disabled, all
  5589.       segment registers loaded, and EAX destroyed.
  5590.  
  5591. (Table 03552)
  5592. Values for calling QEMM QPI function 11h:
  5593.     AH = 11h get memory type map
  5594.     AL = zero/nonzero ??? (set by QEMM.COM but apparently ignored
  5595.           by QEMM 6.00)
  5596.     ES:DI -> 256-byte buffer for memory types
  5597. Return: CF clear
  5598.     BL = ???
  5599.     ES:DI buffer filled
  5600. Note:    each byte of the buffer corresponds to a 4K page, and
  5601.       contains the type of that page: 00h = mappable,
  5602.       02h = mapped ROM, 03h = high RAM, 04h = excluded,
  5603.       05h = video, 06h = ROM, 07h = adapter ROM,
  5604.       08h = split ROM, 09h = page frame, 0Ah = RAMmable,
  5605.       0Bh = conventional, 83h = high RAM under MS Windows
  5606.  
  5607. (Table 03553)
  5608. Values for calling QEMM QPI function 12h:
  5609.     AH = 12h get HIRAM chain
  5610. Return: CF clear
  5611.     BX = segment of first MCB in high memory
  5612.         0000h if no high memory
  5613.  
  5614. (Table 03554)
  5615. Values for calling QEMM QPI function 1300h:
  5616.     AX = 1300h VIDRAMEGA???
  5617.     BL = 00h copy ???
  5618.          nonzero copy ??? (reverse)
  5619. Return: CF clear
  5620.     AL = status
  5621.         00h if all pages clean
  5622.         01h if any page dirty
  5623.  
  5624. (Table 03555)
  5625. Values for calling QEMM QPI function 1301h:
  5626.     AX = 1301h check if pages modified
  5627.     DX:DI = start address of range to check
  5628.     CX = length of range in paragraphs
  5629. Return: CF clear
  5630.     CX = status
  5631.         0000h none of the indicated pages is dirty
  5632.         DI destroyed
  5633.         1000h one or more pages is dirty
  5634.         DI = low word of first dirty page's linear addr
  5635.  
  5636. (Table 03556)
  5637. Values for calling QEMM QPI function 1302h:
  5638.     AX = 1302h ???
  5639.     BL = ???
  5640.     BH = ???
  5641.     CX = ???
  5642.     SI = offset of ???
  5643.     DI = offset of ???
  5644.     ???
  5645. Return: CF clear
  5646.     ???
  5647. Note:    disables certain interrupts at the two 8259 PICs during
  5648.       execution; also modifies CRT controller during
  5649.       execution under certain circumstances
  5650.  
  5651. (Table 03557)
  5652. Values for calling QEMM QPI function 1303h:
  5653.     AX = 1303h initialize EGA graphics virtualization
  5654.     BX = number of pages (less 1) of EMS to allocate
  5655. Return: CF clear if successful
  5656.         DX = EMS handle
  5657.     CF set on error
  5658.  
  5659. (Table 03558)
  5660. Values for calling QEMM QPI function 1304h:
  5661.     AX = 1304h shutdown EGA graphics virtualization
  5662.     DX = EMS handle being used for virtualization
  5663. Return: CF clear
  5664.  
  5665. (Table 03559)
  5666. Values for calling QEMM QPI function 1305h:
  5667.     AX = 1305h select portion of EGA graphics to virtualize???
  5668.     (related to graphics virtualization, changes memory mappings)
  5669.     CX = start offset within A000h segment of virtualized mem???
  5670. Return: CF clear
  5671. Note:    disables certain interrupts at the two 8259 PICs during
  5672.       execution (see #03566) and runs inside a QEMM
  5673.       critical section
  5674.  
  5675. (Table 03560)
  5676. Values for calling QEMM QPI function 1306h:
  5677.     AX = 1306h set DESQview critical section counter address
  5678.     ES:BX -> WORD DESQview critical section counter or 0000h:0000h
  5679. Return: CF clear
  5680. Note:    also sets a pointer in the low-memory part of QEMM to
  5681.       the current value of INT 15 if ES:BX not 0000h:0000h
  5682.  
  5683. (Table 03561)
  5684. Values for calling QEMM QPI function 1307h:
  5685.     AX = 1307h ??? (changes memory mappings for entire A000h segment)
  5686. Return: CF clear
  5687. Note:    disables certain interrupts at the two 8259 PICs during
  5688.       execution (see #03566) and runs inside a QEMM
  5689.       critical section
  5690.  
  5691. (Table 03562)
  5692. Values for calling QEMM QPI function 1308h:
  5693.     AX = 1308h start/reset CRT controller I/O trapping
  5694.     BL = subfunction
  5695.         00h restore CRTC I/O port trapping to previous state
  5696.         else start trapping all accesses to I/O ports 03B0-03DF
  5697. Return: CF clear
  5698. Note:    if called more than once in a row with BL nonzero, the
  5699.       original state of the I/O port trapping will be lost
  5700.  
  5701. (Table 03563)
  5702. Values for calling QEMM QPI function 1309h:
  5703.     AX = 1309h Hercules mode-change support
  5704.     ES:BX -> new address for Hercules mode-change callback
  5705. Return: CF clear
  5706. Note:    the callback function is called whenever the CRTC mode
  5707.       register is written, with AL set to the value written
  5708.  
  5709. (Table 03564)
  5710. Values for calling QEMM QPI function 130Ah:
  5711.     AX = 130Ah virtualize EGA/VGA DAC registers (I/O ports 03C8h/03C9h)
  5712.     CX:DX -> DAC register virtualization buffer (see #03647)
  5713.         or 0000h:0000h to disable
  5714. Return: CF clear
  5715.  
  5716. (Table 03565)
  5717. Values for calling QEMM QPI function 130Bh:
  5718.     AX = 130Bh ???
  5719.     BL = ??? (??? or 00h)
  5720. Return: CF clear
  5721.     ???
  5722. Note:    calls AX=130Eh in some cases
  5723.  
  5724. (Table 03566)
  5725. Values for calling QEMM QPI function 130Ch:
  5726.     AX = 130Ch set interrupts to mask
  5727.     BX = interrupts to mask out during AX=1302h,AX=1307h,AX=1308h,
  5728.           AX=130Dh,AX=1310h (BL = master PIC, BH = slave PIC)
  5729. Return: CF clear
  5730.  
  5731. (Table 03567)
  5732. Values for calling QEMM QPI function 130Dh:
  5733.     AX = 130Dh map EGA memory at A0000h
  5734.     ???
  5735. Return: CF clear
  5736. Note:    disables certain interrupts at the two 8259 PICs during execution
  5737.       (see #03566) and runs inside a QEMM critical section
  5738.     calls AX=1307h (see #03561)
  5739.  
  5740. (Table 03568)
  5741. Values for calling QEMM QPI function 130Eh:
  5742.     AX = 130Eh ??? (modifies CRT controller setup)
  5743.     ???
  5744. Return: CF clear
  5745.  
  5746. (Table 03569)
  5747. Values for calling QEMM QPI function 130Fh:
  5748.     AX = 130Fh reset ???
  5749. Return: CF clear
  5750.  
  5751. (Table 03570)
  5752. Values for calling QEMM QPI function 1310h:
  5753.     AX = 1310h copy modified pages to physical video RAM???
  5754.     ???
  5755. Return: CF clear
  5756. Note:    disables certain interrupts at the two 8259 PICs during execution
  5757.       (see #03566) and runs inside a QEMM critical section
  5758.     also calls AX=130Dh (see #03567)
  5759.  
  5760. (Table 03571)
  5761. Values for calling QEMM QPI function 1311h:
  5762.     AX = 1311h set ???
  5763.     BL = zero/nonzero???
  5764. Return: CF clear
  5765. Note:    certain operations will be performed with interrupts
  5766.       (as set by AX=130Ch) enabled rather than disabled if
  5767.       called with BL nonzero
  5768.  
  5769. (Table 03572)
  5770. Values for calling QEMM QPI function 1312h:
  5771.     AX = 1312h (v6.02) NOP???
  5772. Note:    called by DV 2.42, but appears to be a NOP in QEMM 6.02
  5773.  
  5774. (Table 03573)
  5775. Values for calling QEMM QPI function 1400h:
  5776.     AX = 1400h initialize DESQview "protection level" support
  5777.     ES:DI -> protection level configuration (at least 24 bytes)
  5778.         (see #03641)
  5779.     BL = highest ??? to return (one less than number of words)
  5780. Return: CF clear
  5781.     AX = ??? (4204h for v6.00)
  5782. Note:    QEMM also sets the protected mode INT 02 and INT 06
  5783.       vectors to alternate handlers in certain cases
  5784.  
  5785. (Table 03574)
  5786. Values for calling QEMM QPI function 1401h:
  5787.     AX = 1401h turn off DESQview protection level support
  5788.         Return: CF clear
  5789.             ???
  5790.         Notes:    clears the DV critical-section flag address set with
  5791.               function 1306h
  5792.             QEMM also sets the protected mode INT 02 and INT 06
  5793.               vectors to the default handlers if they had been
  5794.               revectored by function 1400h
  5795.  
  5796. (Table 03575)
  5797. Values for calling QEMM QPI function 1402h:
  5798.     AX = 1402h set protection level???
  5799.         BL = protection level???
  5800.             00h NOP
  5801.             01h ???
  5802.             02h ???
  5803.             other (03h) ???
  5804.         ES:DI -> ???
  5805.         Return: CF clear
  5806.             ???
  5807.         Format of Data structure:
  5808.         Offset    Size    Description
  5809.          00h    WORD    segment of ??? (X, word at X:0136h set to X)
  5810.          02h    WORD    segment of ??? (word at X:0124h set to this)
  5811.          04h    WORD    number of paragraphs of ???
  5812.          06h  3 WORDs    ??? (copied to X:0000h)
  5813.          0Ch    WORD    ???
  5814.  
  5815. (Table 03576)
  5816. Values for calling QEMM QPI function 1403h:
  5817.     AX = 1403h add ??? to end of list and ??? (execute func 1406h)
  5818.         ES:DI -> ??? structure added to end of ??? list
  5819.             (at least 31 bytes, DWORD at offset 06h used for
  5820.              storing pointer to next struc, WORD at offset 00h
  5821.              seems to be a key or index)
  5822.         Return: CF clear
  5823.  
  5824. (Table 03577)
  5825. Values for calling QEMM QPI function 1404h:
  5826.     AX = 1404h NOP
  5827.         Return: CF clear
  5828.  
  5829. (Table 03578)
  5830. Values for calling QEMM QPI function 1405h:
  5831.     AX = 1405h remove ??? from ??? list
  5832.         BX = key???
  5833.         Return: CF clear
  5834.  
  5835. (Table 03579)
  5836. Values for calling QEMM QPI function 1406h:
  5837.     AX = 1406h ???
  5838.         ???
  5839.         Return: CF clear
  5840.             ???
  5841.         Notes:    this function is a NOP unless protection level 2 or 3
  5842.               is active
  5843.             when not a NOP, one of the actions is to write-protect
  5844.               certain memory pages
  5845.  
  5846. (Table 03580)
  5847. Values for calling QEMM QPI function 1407h:
  5848.     AX = 1407h ???
  5849.         ???
  5850.         Return: CF clear
  5851.             ???
  5852.         Note:    same as function 1406h, but only does anything if
  5853.               protection level 2 is active
  5854.  
  5855. (Table 03581)
  5856. Values for calling QEMM QPI function 1408h:
  5857.     AX = 1408h unprotect???
  5858.         ???
  5859.         Return: CF clear
  5860.             ???
  5861.  
  5862. (Table 03582)
  5863. Values for calling QEMM QPI function 1409h:
  5864.     AX = 1409h abort program causing protection violation???
  5865.         ???
  5866.         Return: CF clear
  5867.             ???
  5868.  
  5869. (Table 03583)
  5870. Values for calling QEMM QPI function 140Ah:
  5871.     AX = 140Ah set ???
  5872.         BX = index of ???
  5873.         Return: CF clear
  5874.             ???
  5875.         Notes:    no range checking is performed on BX
  5876.             this function is a NOP unless protection level 3 active
  5877.  
  5878. (Table 03584)
  5879. Values for calling QEMM QPI function 140Bh:
  5880.     AX = 140Bh get ???
  5881.         BX = index of ???
  5882.         SI = 0000h
  5883.         Return: CF clear
  5884.             SI = segment of 256-byte buffer??? or 0000h
  5885.         Notes:    no range checking is performed on BX
  5886.             this function is a NOP unless protection level 3 active
  5887.  
  5888. (Table 03585)
  5889. Values for calling QEMM QPI function 15h:
  5890.     AH = 15h set timer channel 0 virtualization buffer
  5891.         ES:BX -> WORD buffer for timer channel 0 divisor
  5892.             0000h:0000h to disable virtualization
  5893.         Return: CF clear
  5894.  
  5895. (Table 03586)
  5896. Values for calling QEMM v5.00+ QPI function 1600h:
  5897.     AX = 1600h get memory access status
  5898.         ES:DI -> 256-byte buffer
  5899.         Return: ES:DI buffer filled
  5900.         Note:    each byte of the buffer indicates the status of a 4K
  5901.               page (bit 0 set if read, bit 1 set if written)
  5902.  
  5903. (Table 03587)
  5904. Values for calling QEMM v5.00+ QPI function 1601h:
  5905.     AX = 1601h set memory access status
  5906.         ES:DI -> 256-byte buffer containing access statuses (see #03586)
  5907.  
  5908. (Table 03588)
  5909. Values for calling QEMM v5.00+ QPI function 17h:
  5910.     AH = 17h get memory usage statistics
  5911.         ES:DI -> 81-byte buffer for memory statistics (see #03645)
  5912.         Return: CF clear
  5913.  
  5914. (Table 03589)
  5915. Values for calling QEMM v5.11+ QPI function 18h:
  5916.     AH = 18h check whether conventional memory mapped into address range
  5917.         ES:BX = starting address
  5918.         CX = number of 4K pages
  5919.         Return: CF clear
  5920.             AL = 00h one or more pages is remapped
  5921.                  01h all pages in range are conventional memory
  5922.                 (physical address == virtual address)
  5923.  
  5924. (Table 03590)
  5925. Values for calling QEMM v5.11+ QPI function 19h:
  5926.     AH = 19h NOP
  5927.         Return: CF set
  5928.  
  5929. (Table 03591)
  5930. Values for calling QEMM v5.11+ "QPI_UntrappedIORead" function:
  5931.     AX = 1A00h get byte from I/O port
  5932.     DX = port number
  5933. Return: CF clear
  5934.     BL = port value
  5935. Note:    this function was officially documented with the release of QEMM 7.50
  5936.  
  5937. (Table 03592)
  5938. Values for calling QEMM v5.11+ "QPI_UntrappedIOWrite" function:
  5939.     AX = 1A01h send byte to I/O port
  5940.     BL = value to send
  5941.     DX = port number
  5942. Return: CF clear
  5943. Note:    this function was officially documented with the release of QEMM 7.50
  5944.  
  5945. (Table 03593)
  5946. Values for calling QEMM v5.11+ "QPI_UntrappedIOReadIndexed" function:
  5947.     AX = 1A02h
  5948.     BH = index value to send
  5949.     DX = base port number
  5950. Return: CF clear
  5951.     BL = value read from I/O port (DX+1)
  5952. Note:    this function was officially documented with the release of QEMM 7.50
  5953.  
  5954. (Table 03594)
  5955. Values for calling QEMM v5.11+ "QPI_UntrappedIOWriteIndexed" function:
  5956.     AX = 1A03h send bytes to two consecutive I/O ports
  5957.     BH = value for first I/O port (DX)
  5958.     BL = value for second I/O port (DX+1)
  5959.     DX = base port number
  5960. Return: CF clear
  5961. Note:    this function was officially documented with the release of QEMM 7.50
  5962.  
  5963. (Table 03595)
  5964. Values for calling QEMM v7.03+ "QPI_UntrappedIO" function:
  5965.     AX = 1A04h
  5966.     BX = value to write to port
  5967.     CX = direction and size
  5968.         bit 2: output instead of input
  5969.         bit 3: word instead of byte
  5970.     DX = I/O port to be accessed
  5971. Return: CF clear
  5972.     BX = value read (if CX indicates read)
  5973. Note:    this function was officially documented with the release of QEMM 7.50
  5974.  
  5975. (Table 03596)
  5976. Values for calling QEMM v7.03+ function 1A05h
  5977.     AX = 1A05h
  5978.     ???
  5979. Return: ???
  5980.  
  5981. (Table 03597)
  5982. Values for calling QEMM v7.03+ "QPI_GetIOCallback" function:
  5983.     AX = 1A06h
  5984. Return: CF clear
  5985.     ES:DI -> current I/O callback function (see #03599)
  5986. Note:    this function was officially documented with the release of QEMM 7.50
  5987.  
  5988. (Table 03598)
  5989. Values for calling QEMM v7.03+ "QPI_SetIOCallback" function:
  5990.     AX = 1A07h
  5991.     ES:DI -> new I/O callback function (see #03599)
  5992. Return: CF clear
  5993. Note:    this function was officially documented with the release of QEMM 7.50
  5994.  
  5995. (Table 03599)
  5996. Values QEMM v7.03+ I/O callback function is called with:
  5997.     AL/AX = data to/from trapped port
  5998.     CL = I/O direction (00h = IN instruction, else OUT instruction)
  5999.     DX = I/O port address
  6000. Return: CF clear if port handled by callback function
  6001.     CF set if not handled
  6002.     all other registers returned to application executing the IN or OUT
  6003.       instruction (allowing arbitrary changes to port address, data value,
  6004.       etc.)
  6005. SeeAlso: #03597,#03598
  6006.  
  6007. (Table 03600)
  6008. Values for calling QEMM v7.03+ "QPI_GetPortTrap" function:
  6009.     AX = 1A08h
  6010.     DX = I/O port number
  6011. Return: CF clear
  6012.     BL = trapping state (00h not being trapped, 01h trap installed)
  6013. Note:    this function was officially documented with the release of QEMM 7.50
  6014.  
  6015. (Table 03601)
  6016. Values for calling QEMM v7.03+ "QPI_SetPortTrap" function:
  6017.     AX = 1A09h
  6018.     DX = I/O port number
  6019. Return: CF clear
  6020. Note:    this function was officially documented with the release of QEMM 7.50
  6021.  
  6022. (Table 03602)
  6023. Values for calling QEMM v7.03+ "QPI_ClearPortTrap" function:
  6024.     AX = 1A0Ah
  6025.     DX = I/O port number
  6026. Return: CF clear
  6027. Note:    this function was officially documented with the release of QEMM 7.50
  6028.  
  6029. (Table 03603)
  6030. Values for calling QEMM v5.11+ QPI function 1B00h:
  6031.     AX = 1B00h get EMM Import Structure address
  6032.     ES:DI -> buffer for EMM import data structure (see #03643)
  6033. Return: CF set on error
  6034.     CF clear if successful
  6035. SeeAlso: INT 21/AX=4402h/SF=01h
  6036.  
  6037. (Table 03604)
  6038. Values for calling QEMM v5.11+ QPI function 1B01h:
  6039.     AX = 1B01h disable V86 mode
  6040. Return: CF set on error
  6041.         (i.e. no Global EMM Import rec. allocated)
  6042.     CF clear if successful
  6043. Note:    shuts down EMS and initializes Global EMM Import record; this function
  6044.       is invoked from the callback supplied by INT 2F/AX=1605h
  6045.  
  6046. (Table 03605)
  6047. Values for calling QEMM v5.11+ QPI function 1B02h:
  6048.     AX = 1B02h enable V86 mode
  6049. Return: CF set on error
  6050.     CF clear if successful
  6051. Note:    restarts EMS and frees Global EMM Import record; this function is
  6052.       invoked from the callback supplied by INT 2F/AX=1605h
  6053.  
  6054. (Table 03606)
  6055. Values for calling QEMM v5.11+ QPI function 1B03h:
  6056.     AX = 1B03h MS Windows initializing
  6057.     CX = segment from which Windows init broadcast made???
  6058.     DX = Windows startup flags
  6059.     DI = Windows version number (major in upper byte)
  6060. Return: CF clear if successful
  6061.         DS:SI -> V86 mode enable/disable callback
  6062.           (see #02634 at INT 2F/AX=1605h)
  6063.         ES:BX -> startup info structure (see #02631 at INT 2F/AX=1605h)
  6064.     CF set on error (unable to start Windows)
  6065. SeeAlso: INT 2F/AX=1605h
  6066.  
  6067. (Table 03607)
  6068. Values for calling QEMM v5.11+ QPI function 1B04h:
  6069.     AX = 1B04h MS Windows terminating
  6070. Return: CF clear
  6071.  
  6072. (Table 03608)
  6073. Values for calling QEMM v5.11+ QPI function 1B05h:
  6074.     AX = 1B05h determine whether program is driver
  6075.     DS:DX -> ASCIZ filename
  6076. Return: CF clear
  6077.     AL = status
  6078.         01h if string ends in ".DRV"
  6079.         FFh if string ends in "GDI.EXE"
  6080.         00h otherwise
  6081. Note:    when MS Windows 3.0 standard mode starts, QEMM patches all drivers
  6082.       until GDI.EXE is loaded
  6083.  
  6084. (Table 03609)
  6085. Values for calling QEMM v5.11+ QPI function 1B06h:
  6086.     AX = 1B06h patch protected-mode check in Windows driver
  6087.     CX = length of data pointed at by DS:DX
  6088.     DS:DX -> buffer containing Windows driver code
  6089. Return: CF clear
  6090. Note:    patches all SMSW x/TEST x,1 instruction sequences into MOV x,CS/VERW x
  6091.       sequences, which has the effect that the protected-mode check will
  6092.       only indicate protected mode in native protected mode and not in V86
  6093.       mode
  6094.  
  6095. (Table 03610)
  6096. Values for calling QEMM v5.11+ QPI function 1B07h:
  6097.     AX = 1B07h
  6098. BUG: QEMM 6.00-7.01 accept this and branch randomly
  6099.  
  6100. (Table 03611)
  6101. Values for calling QEMM v5.11+ QPI function 1Bxxh:
  6102.     AX = 1B08h to 1BFFh
  6103. Return: CF set
  6104.  
  6105. (Table 03612)
  6106. Values for calling QEMM v5.11+ QPI function 1C00h:
  6107.     AX = 1C00h disable IRQ0-7 calldowns
  6108. Return: CF clear
  6109.  
  6110. (Table 03613)
  6111. Values for calling QEMM v5.11+ QPI function 1C01h:
  6112.     AX = 1C01h set V86-mode IRQ0-7 handlers
  6113.     ES:DI -> 8 DWORDs containing V86-mode handler addresses
  6114. Return: CF clear
  6115.  
  6116. (Table 03614)
  6117. Values for calling QEMM v5.11+ QPI function 1C02h:
  6118.     AX = 1C02h disable IRQ8-15 handlers
  6119. Return: CF clear
  6120.  
  6121. (Table 03615)
  6122. Values for calling QEMM v5.11+ QPI function 1C03h:
  6123.     AX = 1C03h set V86-mode IRQ8-15 handlers
  6124.     ES:DI -> 8 DWORDs containing V86-mode handler addresses
  6125. BUG:    although the jump table only contains four entries, QEMM 6.00 will
  6126.       attempt to use it for any value of AL between 00h and 2Ah, thus
  6127.       branching unpredictably for AL=04h-2Ah; QEMM v7.01 behaves
  6128.       similarly for AL=04h-1Bh
  6129. Note:    when enabled, the appropriate IRQs are reflected back to the specified
  6130.       handlers in virtual-86 mode after the CPU automatically invokes the
  6131.       protected-mode handler inside QEMM
  6132.  
  6133. (Table 03616)
  6134. Values for calling QEMM v7.03+ "QPI_SimulateHWInt" function:
  6135.     AX = 1C04h
  6136.     BX = number of interrupt to simulate
  6137. Return: ???
  6138. Notes:    this function will allow proper simulation of a hardware interrupt
  6139.       under DESQview and DESQview/X, where the correct interrupt handler
  6140.       may be in a different process with a completely different address
  6141.       space
  6142.     this function was officially documented with the release of QEMM v7.50
  6143.  
  6144. (Table 03617)
  6145. Values for calling QEMM v6.0x only QPI function 1D00h:
  6146.     AX = 1D00h switch to pre-Stealth interrupt vector table
  6147. Return: CF clear if supported (QEMM v6.x)
  6148.     CF set if not supported (QEMM v7+)
  6149. Notes:    also switches VGA Save table pointer (0040h:00A8h) and overwrites the
  6150.       vectors currently assigned for use by the two interrupt controllers
  6151.       (see INT 67/AX=DE0Ah) with the vectors for INT 08-0F and 70-77 (to
  6152.       avoid crashing the system).
  6153.     functions 1Dxxh are not supported by QEMM v7.01, and always return CF
  6154.       set
  6155.  
  6156. (Table 03618)
  6157. Values for calling QEMM v6.0x only QPI function 1D01h:
  6158.     AX = 1D01h restore user interrupt vector table
  6159. Return: CF clear if supported (QEMM v6.x)
  6160.     CF set if not supported (QEMM v7+)
  6161. Notes:    interrupts should be disabled around the AX=1D00h and AX=1D01h calls
  6162.       because QEMM does not modify the memory maps to map in ROM, so
  6163.       an interrupt could be disastrous
  6164.     clears any pending IRQ7 at end of function
  6165.     functions 1Dxxh are not supported by QEMM v7.01, and always return CF
  6166.       set
  6167.  
  6168. (Table 03619)
  6169. Values for calling QEMM v6.00+ QPI function 1Dxxh:
  6170.     AX = 1D02h to 1DFFh
  6171. Return: CF set
  6172.  
  6173. (Table 03620)
  6174. Values for calling QEMM v6.00+ "QEMM_GET_INFO"/"QPI_GetInfo" function:
  6175.     AX = 1E00h get Stealth configuration
  6176. Return: CF clear
  6177.     BL = memory configuration flags (documented as "reserved") (see #03644)
  6178.     BH = (v7.00+) disk buffer flags
  6179.         bit 0: DISKBUFFRAME buffer instead of DISKBUF buffer
  6180.         bit 1: buffer has already been used
  6181.     CL = stealth type (00h none, 46h Frame, 4Dh Map, 50h Protect)
  6182.     CH = suspend/resume interrupt (00h none)
  6183.     DL = (v7.00+) size of QEMM disk buffer in KB (00h none)
  6184.     DH = reserved (always 00h for v6.00)
  6185.     SI = reserved (always 0000h for v6.00)
  6186.     DI = reserved (always 0000h for v6.00)
  6187. Note:    this function is officially documented
  6188.  
  6189. (Table 03621)
  6190. Values for calling QEMM v6.00+ "QPI_GetStealthCount" function:
  6191.     AX = 1E01h get number of Stealth'ed ROMs
  6192. Return: CF clear
  6193.     BX = number of Stealth'ed ROMs
  6194. Note:    this function is officially documented
  6195.  
  6196. (Table 03622)
  6197. Values for calling QEMM v6.00+ "QPI_GetStealthList" function:
  6198.     AX = 1E02h
  6199.     ES:DI -> buffer for Stealth ROM info (see #03646)
  6200. Return: CF clear
  6201.     BX = number of Stealth'ed ROMs
  6202.     ES:DI buffer filled
  6203. Note:    this function is officially documented
  6204.  
  6205. (Table 03623)
  6206. Values for unimplemented Stealth information functions:
  6207.     AX = 1E03h to 1EFFh
  6208. Return: CF set
  6209.  
  6210.  
  6211. (Table 03624)
  6212. Values for calling QEMM v6.00+ "QEMM_GET_PTE"/"QPI_GetPTE" function:
  6213.     AX = 1F00h get page table entry
  6214.     CX = page number (0000h-010Fh)
  6215. Return: CF clear
  6216.     EDX = page table entry
  6217. Note:    this function is officially documented
  6218.  
  6219. (Table 03625)
  6220. Values for calling QEMM v6.00+ "QEMM_SET_PTE"/"QPI_SetPTE" function:
  6221.     AX = 1F01h set page table entry
  6222.     CX = page number (0000h-010Fh)
  6223.     EDX = new page table entry
  6224. Return: CF clear
  6225. Note:    this function is officially documented
  6226. SeeAlso: #03549
  6227.  
  6228. (Table 03626)
  6229. Values for calling QEMM v6.00+ QPI function 1Fxxh:
  6230.     AX = 1F02h to 1FFFh
  6231. Return: CF set
  6232.  
  6233. (Table 03627)
  6234. Values for calling QEMM v6.00+ "QEMM_GET_VHI_INFO"/"QPI_GetVHIInfo" function:
  6235.     AX = 2000h "QEMM_GET_VHI_INFO" get VirtualHDIRQ information
  6236. Return: CF clear
  6237.     BL = flags
  6238.         bit 7: VirtualHDIRQ setting respected
  6239.           (set if Stealth active)
  6240.         bits 6-1 reserved
  6241.         bit 0: VirtualHDIRQ currently enabled
  6242.         (INT 15/AH=90h suppressed when enabled)
  6243. Note:    this function is officially documented
  6244. SeeAlso: #03628
  6245.  
  6246. (Table 03628)
  6247. Values for calling QEMM v6.00+ "QEMM_SET_VHI_INFO"/"QPI_SetVHIInfo" function:
  6248.     AX = 2001h set VirtualHDIRQ state
  6249.     BL bit 0 = new VirtualHDIRQ state
  6250. Return: CF clear
  6251.     BL = old VHI setting (bits 0 and 7, see #03627)
  6252. Note:    this function is officially documented
  6253. SeeAlso: #03627
  6254.  
  6255. (Table 03629)
  6256. Values for calling QEMM v6.00+ QPI function 20xxh:
  6257.     AX = 2002h to 20FFh
  6258. Return: CF set
  6259.  
  6260. (Table 03630)
  6261. Values for calling QEMM v6.00+ "QEMM_COPY_STEALTH_ROMS"/"QPI_CopyStealthRoms":
  6262.     AX = 2100h copy data from Stealthed address space
  6263.     DS:SI -> start address of hidden memory to copy
  6264.     ES:DI -> buffer for copied data
  6265.     ECX = number of bytes to copy
  6266. Return: CF clear if successful
  6267.     CF set on error (no Stealth or DS:SI < C000h:0000h or DS:SI + ECX > 1M)
  6268. Note:    this function was officially documented with the release of QEMM 7.50
  6269.  
  6270. (Table 03631)
  6271. Values for calling QEMM v6.00+ QPI function 21xxh:
  6272.     AX = 2101h to 21FFh
  6273. Return: CF set
  6274.  
  6275. (Table 03632)
  6276. Values for calling QEMM v6.03+ QPI function 2200h:
  6277.     AX = 2200h DESQview/X support -- get ???
  6278. Return: CF clear
  6279.     ES:DI -> ???
  6280.  
  6281. (Table 03633)
  6282. Values for calling QEMM v6.03+ QPI function 2201h:
  6283.     AX = 2201h DESQview/X support -- set ???
  6284.     ES:DI -> ??? or 0000h:0000h
  6285. Return: CF clear if successful
  6286.     CF set on error
  6287.  
  6288. (Table 03634)
  6289. Values for calling QEMM v6.04+ QPI function 2300h:
  6290.     AX = 2300h get ???
  6291.     BX = which ??? to get (must be 0000h for v6.04)
  6292. Return: CF clear if successful
  6293.         ES:DI -> ???
  6294.     CF set on error
  6295.  
  6296. (Table 03635)
  6297. Values for calling QEMM v6.04+ QPI function 2301h:
  6298.     AX = 2301h set ???
  6299.     BX = which ??? to set (must be 0000h for v6.04)
  6300.     ES:DI -> ???
  6301. Return: CF clear if successful
  6302.     CF set on error
  6303.  
  6304. (Table 03636)
  6305. Values for calling QEMM v6.04+ QPI function 2302h:
  6306.     AX = 2302h clear specified ???
  6307.     BX = which ??? to clear (must be 0000h for v6.04)
  6308. Return: CF clear if successful
  6309.     CF set on error
  6310.  
  6311. (Table 03637)
  6312. Values for calling QEMM v6.04+ QPI function 23FFh:
  6313.     AX = 23FFh clear all ???
  6314. Return: CF clear if successful
  6315.     CF set on error
  6316.  
  6317. (Table 03638)
  6318. Values for calling QEMM v6.04+ QPI function 23xxh:
  6319.     AX = 2303h to 23FEh
  6320. Return: CF set
  6321.  
  6322. (Table 03639)
  6323. Values for calling QEMM v7.01+ QPI function 24h:
  6324.     AH = 24h ST-DBL support
  6325.     AL = subfunction
  6326.         00h set ???
  6327.         EDX -> information table (EDX = segment SHL 16 + offset)
  6328.         01h ???
  6329. Return: CF clear if successful
  6330.     CF set on error
  6331.  
  6332. (Table 03640)
  6333. Values for calling QEMM unimplemented QPI functions:
  6334.     AH = 25h to FFh
  6335. Return: CF set
  6336.  
  6337. Format of QEMM protection level configuration:
  6338. Offset    Size    Description    (Table 03641)
  6339.  00h    WORD    segment of 128 breakpoint (INT 3) instructions for use in
  6340.           DESQview protection level 3 interrupt vector checking, or
  6341.           0000h to disable; in pl3, INTs 00-7F are pointed at these
  6342.           breakpoints
  6343.  02h    DWORD    -> array of actual interrupt handler addresses for INT 00-7F
  6344.           when interrupt vectors are pointed at protection level 3
  6345.           breakpoints
  6346.  06h    DWORD    far pointer to ??? region list (see #03642)
  6347.  0Ah    DWORD    far pointer to buffer for returned ???
  6348.  0Eh    DWORD    seg:ofs of function to call on protection violation???
  6349.  12h    WORD    segment of ???
  6350.  14h    DWORD    far pointer to DWORD containing number of paragraphs of
  6351.           ??? for segment at offset 12h
  6352.     ???
  6353.  
  6354. Format of protection level Region List:
  6355. Offset    Size    Description    (Table 03642)
  6356.  00h    WORD    number of PAIRS of pointers to follow
  6357.  02h 2N DWORDs    start/end seg:ofs addresses of ??? regions
  6358. Note:    QEMM converts the segmented addresses into linear addresses in place
  6359.  
  6360. Format of EMM Import structure:
  6361. Offset    Size    Description    (Table 03643)
  6362.  00h    DWORD    physical address of EMM import struct
  6363.  04h    BYTE    major version (v6.00 sets to 01h)
  6364.  05h    BYTE    minor version (v6.00 sets to 00h/0Bh)
  6365. SeeAlso: INT 21/AX=4402h/SF=01h
  6366.  
  6367. Bitfields for memory configuration flags:
  6368. Bit(s)    Description    (Table 03644)
  6369.  0    conventional memory sorted
  6370.  1    conventional memory filled
  6371.  2    ???
  6372.  3    ???
  6373.  4    expanded memory is in use
  6374.  5    ???
  6375.  
  6376. Format of QEMM 6.0 memory statistics:
  6377. Offset    Size    Description    (Table 03645)
  6378.  00h    BYTE    01h if Shadow RAM found, 00h otherwise
  6379.  01h    DWORD    initial conventional memory in bytes
  6380.  05h    DWORD    initial extended memory in bytes
  6381.  09h    DWORD    initial expanded memory in bytes
  6382.  0Dh    DWORD    initial "top" or "shadow" memory in bytes
  6383.  11h    DWORD    Unavailable conventional memory in bytes
  6384.  15h    DWORD    Unavailable extended memory in bytes
  6385.  19h    DWORD    Unavailable expanded memory in bytes
  6386.  1Dh    DWORD    Unavailable "top" or "shadow" memory in bytes
  6387.         Add to offset 49h for Total unavailable top/shadow.
  6388.  21h    DWORD    QEMM code size in bytes
  6389.  25h    DWORD    QEMM data size in bytes
  6390.  29h    DWORD    bytes used for TASKS=
  6391.  2Dh    DWORD    DMA buffer size
  6392.  31h    DWORD    bytes used for MAPS=
  6393.  35h    DWORD    bytes of high RAM
  6394.  39h    DWORD    bytes used by mapped ROMs
  6395.  3Dh    DWORD    bytes of conventional memory provided by QEMM
  6396.  41h    DWORD    bytes of extended memory NOT converted by QEMM (EXT=xxx)
  6397.  45h    DWORD    bytes of EMS/XMS pool memory provided by QEMM
  6398.  49h    DWORD    Unavailable "top" or "shadow" memory in bytes
  6399.         Add to offset 1Dh for Total unavailable top/shadow.
  6400.  4Dh    DWORD    conventional memory overhead in bytes
  6401.         (set to 0 by QEMM.COM prior to call)
  6402.  
  6403. Format of Stealth ROM info [array]:
  6404. Offset    Size    Description    (Table 03646)
  6405.  00h    WORD    starting segment of ROM
  6406.  02h    WORD    length of ROM in paragraphs
  6407.  
  6408. Format of QEMM EGA/VGA DAC register virtualization buffer:
  6409. Offset    Size    Description    (Table 03647)
  6410.  00h    BYTE    (temp) current color register number
  6411.  01h    BYTE    (temp) number of bytes written so far for current color reg
  6412.  02h 768 BYTEs    three bytes per color register
  6413. --------m-6740-------------------------------
  6414. INT 67 - LIM EMS - GET MANAGER STATUS
  6415.     AH = 40h
  6416. Return: AH = status (00h,80h,81h,84h) (see #03648)
  6417. Note:    this call can be used only after establishing that the EMS driver is in
  6418.       fact present
  6419. SeeAlso: AH=3Fh,AX=FFA5h,@xxxxh:xxxxh"PMM"
  6420.  
  6421. (Table 03648)
  6422. Values for EMS function status:
  6423.  00h    successful
  6424.  80h    internal error
  6425.  81h    hardware malfunction
  6426.  82h    busy -- retry later
  6427.  83h    invalid handle
  6428.  84h    undefined function requested by application
  6429.  85h    no more handles available
  6430.  86h    error in save or restore of mapping context
  6431.  87h    insufficient memory pages in system
  6432.  88h    insufficient memory pages available
  6433.  89h    zero pages requested
  6434.  8Ah    invalid logical page number encountered
  6435.  8Bh    invalid physical page number encountered
  6436.  8Ch    page-mapping hardware state save area is full
  6437.  8Dh    save of mapping context failed
  6438.  8Eh    restore of mapping context failed
  6439.  8Fh    undefined subfunction
  6440.  90h    undefined attribute type
  6441.  91h    feature not supported
  6442.  92h    successful, but a portion of the source region has been overwritten
  6443.  93h    length of source or destination region exceeds length of region
  6444.       allocated to either source or destination handle
  6445.  94h    conventional and expanded memory regions overlap
  6446.  95h    offset within logical page exceeds size of logical page
  6447.  96h    region length exceeds 1M
  6448.  97h    source and destination EMS regions have same handle and overlap
  6449.  98h    memory source or destination type undefined
  6450.  9Ah    specified alternate map register or DMA register set not supported
  6451.  9Bh    all alternate map register or DMA register sets currently allocated
  6452.  9Ch    alternate map register or DMA register sets not supported
  6453.  9Dh    undefined or unallocated alternate map register or DMA register set
  6454.  9Eh    dedicated DMA channels not supported
  6455.  9Fh    specified dedicated DMA channel not supported
  6456.  A0h    no such handle name
  6457.  A1h    a handle found had no name, or duplicate handle name
  6458.  A2h    attempted to wrap around 1M conventional address space
  6459.  A3h    source array corrupted
  6460.  A4h    operating system denied access
  6461. --------m-6741-------------------------------
  6462. INT 67 - LIM EMS - GET PAGE FRAME SEGMENT
  6463.     AH = 41h
  6464. Return: AH = status (see also AH=40h)
  6465.         00h function successful
  6466.         BX = segment of page frame
  6467. SeeAlso: AH=58h,AH=68h
  6468. --------m-6742-------------------------------
  6469. INT 67 - LIM EMS - GET NUMBER OF PAGES
  6470.     AH = 42h
  6471. Return: AH = status (see also AH=40h)
  6472.         00h function successful
  6473.         BX = number of unallocated pages
  6474.         DX = total number of pages
  6475. BUG:    DOS 6.0 EMM386.EXE causes a system lock-up or reboot if in AUTO mode
  6476.       when this call is made; use AH=46h to ensure that EMM386 is ON
  6477.       before making this call
  6478. SeeAlso: INT 2F/AX=2702h
  6479. --------m-6743-------------------------------
  6480. INT 67 - LIM EMS - GET HANDLE AND ALLOCATE MEMORY
  6481.     AH = 43h
  6482.     BX = number of logical pages to allocate
  6483. Return: AH = status (00h,80h,81h,84h,85h,87h,88h,89h) (see #03648)
  6484.     DX = handle if AH=00h
  6485. SeeAlso: AH=45h
  6486. --------u-674321-----------------------------
  6487. INT 67 - Q87 v4+ - INSTALLATION CHECK
  6488.     AX = 4321h
  6489.     EAX = 87654321h (entire EAX value required)
  6490. Return: EAX = 12345678h if Q87 is installed
  6491. Note:    this call requires that VCPI services be available; if they are not,
  6492.       this call will not be recognized
  6493. BUG:    v4.00-v4.03 will hang on most machines when run under bare DOS with
  6494.       no memory manager, because neither Q87 nor UNLOAD87 checks whether
  6495.       there is a valid INT 67 handler before performing an installation
  6496.       check via INT 67
  6497. SeeAlso: AX=2833h,INT 21/AX=4321h
  6498. --------m-6744-------------------------------
  6499. INT 67 - LIM EMS - MAP MEMORY
  6500.     AH = 44h
  6501.     AL = physical page number (0-3)
  6502.     BX = logical page number
  6503.         or FFFFh to unmap (QEMM)
  6504.     DX = handle
  6505. Return: AH = status (00h,80h,81h,83h,84h,8Ah,8Bh) (see #03648)
  6506. SeeAlso: AH=69h
  6507. --------m-6745-------------------------------
  6508. INT 67 - LIM EMS - RELEASE HANDLE AND MEMORY
  6509.     AH = 45h
  6510.     DX = EMM handle
  6511. Return: AH = status (00h,80h,81h,83h,84h,86h) (see #03648)
  6512. SeeAlso: AH=43h
  6513. --------m-6746-------------------------------
  6514. INT 67 - LIM EMS - GET EMM VERSION
  6515.     AH = 46h
  6516. Return: AH = status (00h,80h,81h,84h) (see #03648)
  6517.     AL = EMM version number if AH=00h
  6518. --------m-6747-------------------------------
  6519. INT 67 - LIM EMS - SAVE MAPPING CONTEXT
  6520.     AH = 47h
  6521.     DX = handle
  6522. Return: AH = status (00h,80h,81h,83h,84h,8Ch-8Eh) (see #03648)
  6523. SeeAlso: AH=48h
  6524. --------m-6748-------------------------------
  6525. INT 67 - LIM EMS - RESTORE MAPPING CONTEXT
  6526.     AH = 48h
  6527.     DX = handle
  6528. Return: AH = status (00h,80h,81h,83h,84h,8Eh) (see #03648)
  6529. SeeAlso: AH=47h
  6530. --------m-6749-------------------------------
  6531. INT 67 - LIM EMS - reserved - GET I/O PORT ADDRESSES
  6532.     AH = 49h
  6533. Note:    defined in EMS 3.0, but undocumented in EMS 3.2
  6534. --------m-674A-------------------------------
  6535. INT 67 - LIM EMS - reserved - GET TRANSLATION ARRAY
  6536.     AH = 4Ah
  6537. Note:    defined in EMS 3.0, but undocumented in EMS 3.2
  6538. --------m-674B-------------------------------
  6539. INT 67 - LIM EMS - GET NUMBER OF EMM HANDLES
  6540.     AH = 4Bh
  6541. Return: AH = status (00h,80h,81h,83h,84h) (see #03648)
  6542.     BX = number of EMM handles if AH=00h
  6543. --------m-674C-------------------------------
  6544. INT 67 - LIM EMS - GET PAGES OWNED BY HANDLE
  6545.     AH = 4Ch
  6546.     DX = EMM handle
  6547. Return: AH = status (see #02785)
  6548.     BX = number of logical pages if AH=00h
  6549. SeeAlso: AH=4Dh
  6550. --------m-674D-------------------------------
  6551. INT 67 - LIM EMS - GET PAGES FOR ALL HANDLES
  6552.     AH = 4Dh
  6553.     ES:DI -> array to receive information
  6554. Return: AH = status (00h,80h,81h,84h) (see #03648)
  6555.     ---if AH=00h---
  6556.     BX = number of active EMM handles
  6557.     array filled with 2-word entries, consisting of a handle and the
  6558.       number of pages allocated to that handle
  6559. SeeAlso: AH=4Ch
  6560. --------m-674E-------------------------------
  6561. INT 67 - LIM EMS - GET OR SET PAGE MAP
  6562.     AH = 4Eh
  6563.     AL = subfunction
  6564.         00h get mapping registers
  6565.         01h set mapping registers
  6566.         02h get and set mapping registers at once
  6567.         03h get size of page-mapping array
  6568.     DS:SI -> array holding information (AL=01h/02h)
  6569.     ES:DI -> array to receive information (AL=00h/02h)
  6570. Return: AH = status (00h,80h,81h,84h,8Fh,A3h) (see also AH=40h)
  6571.         00h successful
  6572.         AL = bytes in page-mapping array (AL=03h only)
  6573.         array pointed to by ES:DI receives mapping info (AL=00h/02h)
  6574. Notes:    this function was designed to be used by multitasking operating systems
  6575.       and should not ordinarily be used by appplication software.
  6576.     MD386 returns the size of the page-mapping array in AX instead of AL
  6577. SeeAlso: AH=4Fh
  6578. --------m-674F-------------------------------
  6579. INT 67 - LIM EMS 4.0 - GET/SET PARTIAL PAGE MAP
  6580.     AH = 4Fh
  6581.     AL = subfunction
  6582.         00h get partial page map
  6583.            DS:SI -> structure containing list of segments whose mapping
  6584.             contexts are to be saved
  6585.            ES:DI -> array to receive page map
  6586.         01h set partial page map
  6587.            DS:SI -> structure containing saved partial page map
  6588.         02h get size of partial page map
  6589.            BX = number of mappable segments in the partial map to be saved
  6590. Return: AH = status (00h,80h,81h,84h,8Bh,8Fh,A3h) (see also AH=40h)
  6591.         8Bh one of the specified segments is not mappable
  6592.         A3h contents of partial page map corrupted or count of mappable
  6593.         segments exceeds total number of mappable segments in system
  6594.     AL = size of partial page map for subfunction 02h
  6595. SeeAlso: AH=4Eh
  6596. --------m-6750-------------------------------
  6597. INT 67 - LIM EMS 4.0 - MAP/UNMAP MULTIPLE HANDLE PAGES
  6598.     AH = 50h
  6599.     AL = subfunction
  6600.         00h use physical page numbers
  6601.         01h use segment addresses
  6602.     DX = handle
  6603.     CX = number of entries in array
  6604.     DS:SI -> mapping array (see #03649)
  6605. Return: AH = status (00h,80h,81h,83h,84h,8Ah,8Bh,8Fh) (see #03648)
  6606. SeeAlso: AH=40h
  6607.  
  6608. Format of EMS mapping array entry:
  6609. Offset    Size    Description    (Table 03649)
  6610.  00h    WORD    logical page number or FFFFh to unmap physical page
  6611.  02h    WORD    physical page number or segment address
  6612. --------m-6751-------------------------------
  6613. INT 67 - LIM EMS 4.0 - REALLOCATE PAGES
  6614.     AH = 51h
  6615.     DX = handle
  6616.     BX = number of pages to be allocated to handle
  6617. Return: AH = status (00h,80h,81h,83h,84h,87h,88h) (see #03650)
  6618.     BX = actual number of pages allocated to handle
  6619.  
  6620. (Table 03650)
  6621. Values for EMS function status:
  6622.  00h    successful
  6623.  80h    internal error
  6624.  81h    hardware malfunction
  6625.  83h    invalid handle
  6626.  84h    undefined function requested
  6627.  87h    more pages requested than present in system
  6628.  88h    more pages requested than currently available
  6629.  8Ah    invalid logical page number encountered
  6630.  8Bh    invalid physical page number encountered
  6631.  8Fh    undefined subfunction
  6632.  90h    undefined attribute type
  6633.  91h    feature not supported
  6634.  A0h    no such handle name
  6635.  A1h    duplicate handle name
  6636. --------m-6752-------------------------------
  6637. INT 67 - LIM EMS 4.0 - GET/SET HANDLE ATTRIBUTES
  6638.     AH = 52h
  6639.     AL = subfunction
  6640.         00h get handle attributes
  6641.         Return: AL = attribute
  6642.                 00h handle is volatile
  6643.                 01h handle is nonvolatile
  6644.         01h set handle attributes
  6645.         BL = new attribute
  6646.            00h handle is volatile
  6647.            01h handle is nonvolatile
  6648.         02h get attribute capability
  6649.         Return: AL = attribute capability
  6650.                 00h only volatile handles supported
  6651.                 01h both volatile and non-volatile supported
  6652.     DX = handle
  6653. Return: AH = status (00h,80h,81h,83h,84h,8Fh-91h) (see #03648)
  6654. SeeAlso: AH=53h
  6655. --------m-6753-------------------------------
  6656. INT 67 - LIM EMS 4.0 - GET/SET HANDLE NAME
  6657.     AH = 53h
  6658.     AL = subfunction
  6659.         00h get handle name
  6660.            ES:DI -> 8-byte buffer for handle name
  6661.         01h set handle name
  6662.            DS:SI -> 8-byte handle name
  6663.     DX = handle
  6664. Return: AH = status (00h,80h,81h,83h,84h,8Fh,A1h) (see #03648)
  6665. SeeAlso: AH=52h
  6666. --------m-6754-------------------------------
  6667. INT 67 - LIM EMS 4.0 - GET HANDLE DIRECTORY
  6668.     AH = 54h
  6669.     AL = subfunction
  6670.         00h get handle directory
  6671.            ES:DI -> buffer for handle directory (see #03651)
  6672.         01h search for named handle
  6673.            DS:SI -> 8-byte name
  6674.         02h get total number of handles
  6675. Return: AL = number of entries in handle directory (subfunction 00h)
  6676.     DX = value of named handle (subfunction 01h)
  6677.     BX = total number of handles (subfunction 02h)
  6678.     AH = status (00h,80h,81h,84h,8Fh,A0h,A1h) (see also #03650)
  6679.         A1h a handle found had no name
  6680.  
  6681. Format of EMS handle directory entry:
  6682. Offset    Size    Description    (Table 03651)
  6683.  00h    WORD    handle
  6684.  02h  8 BYTEs    handle's name
  6685. --------m-6755-------------------------------
  6686. INT 67 - LIM EMS 4.0 - ALTER PAGE MAP AND JUMP
  6687.     AH = 55h
  6688.     AL = subfunction
  6689.         00h physical page numbers provided by caller
  6690.         01h segment addresses provided by caller
  6691.     DX = handle
  6692.     DS:SI -> structure containing map and jump address
  6693. Return: (at target address unless error)
  6694.     AH = status (00h,80h,81h,83h,84h,8Ah,8Bh,8Fh) (see #03648)
  6695. SeeAlso: AH=56h
  6696. --------m-6756-------------------------------
  6697. INT 67 - LIM EMS 4.0 - ALTER PAGE MAP AND CALL
  6698.     AH = 56h
  6699.     AL = subfunction
  6700.         00h physical page numbers provided by caller
  6701.         DX = handle
  6702.         DS:SI -> structure containing page map and call address
  6703.         01h segment addresses provided by caller
  6704.         DX = handle
  6705.         DS:SI -> structure containing page map and call address
  6706.         02h get page map stack space required
  6707.         Return: BX = stack space required
  6708. Return: (if successful, the target address is called.  Use a RETF to return
  6709.      and restore mapping context)
  6710.     AH = status (00h,80h,81h,83h,84h,8Ah,8Bh,8Fh) (see #03648)
  6711. SeeAlso: AH=55h
  6712. --------m-6756FF-----------------------------
  6713. INT 67 - RM386 v6.00 - ???
  6714.     AX = 56FFh
  6715.     DS:SI -> ???
  6716.     ???
  6717. Return: ???
  6718. --------m-6757-------------------------------
  6719. INT 67 - LIM EMS 4.0 - MOVE/EXCHANGE MEMORY REGION
  6720.     AH = 57h
  6721.     AL = subfunction
  6722.         00h move memory region
  6723.         01h exchange memory region
  6724.     DS:SI -> structure describing source and destination (see #03653)
  6725. Return: AH = status (see #03652)
  6726. Note:    source and destination may overlap for a move, in which case the copy
  6727.       direction is chosen such that the destination receives an intact copy
  6728.       of the source region
  6729.  
  6730. (Table 03652)
  6731. Values for EMS function status:
  6732.  00h    successful
  6733.  80h    internal error
  6734.  81h    hardware failure
  6735.  83h    invalid handle
  6736.  84h    undefined function requested
  6737.  8Ah    invalid logical page number encountered
  6738.  8Fh    undefined subfunction
  6739.  92h    successful, but a portion of the source region has been overwritten
  6740.  93h    length of source or destination region exceeds length of region
  6741.       allocated to either source or destination handle
  6742.  94h    conventional and expanded memory regions overlap
  6743.  95h    offset within logical page exceeds size of logical page
  6744.  96h    region length exceeds 1M
  6745.  97h    source and destination EMS regions have same handle and overlap
  6746.  98h    memory source or destination type undefined
  6747.  A2h    attempted to wrap around 1M conventional address space
  6748.  
  6749. Format of EMS copy data:
  6750. Offset    Size    Description    (Table 03653)
  6751.  00h    DWORD    region length in bytes
  6752.  04h    BYTE    source memory type
  6753.         00h conventional
  6754.         01h expanded
  6755.  05h    WORD    source handle (0000h if conventional memory)
  6756.  07h    WORD    source initial offset (within page if EMS, segment if convent)
  6757.  09h    WORD    source initial segment (conv mem) or logical page (EMS)
  6758.  0Bh    BYTE    destination memory type
  6759.         00h conventional
  6760.         01h expanded
  6761.  0Ch    WORD    destination handle
  6762.  0Eh    WORD    destination initial offset
  6763.  10h    WORD    destination initial segment or page
  6764. --------m-6758-------------------------------
  6765. INT 67 - LIM EMS 4.0 - GET MAPPABLE PHYSICAL ADDRESS ARRAY
  6766.     AH = 58h
  6767.     AL = subfunction
  6768.         00h get mappable physical address array
  6769.         ES:DI -> buffer to be filled with array (see #03654)
  6770.         01h get number of entries in m.p.a. array
  6771. Return: CX = number of entries in array
  6772.     AH = status (00h,80h,81h,84h,8Fh) (see #03652)
  6773. Note:    the returned array for subfunction 00h is filled in physical segment
  6774.       address order
  6775.  
  6776. Format of EMS mappable physical address entry:
  6777. Offset    Size    Description    (Table 03654)
  6778.  00h    WORD    physical page segment
  6779.  02h    WORD    physical page number
  6780. --------m-675857-----------------------------
  6781. INT 67 U - NETROOM??? - ???
  6782.     AX = 5857h
  6783.     BX = function??? (0057h,0059h,0159h seen)
  6784.     ???
  6785. Return: ???
  6786. Note:    BX=0059h appears to be analogous to AX=5800h and BX=0159h appears to
  6787.       be analogous to AX=5801h; BX=0057h appears to indicate whether
  6788.       AX=580xh or AX=5857h/BX=0x59h should be used
  6789. SeeAlso: AX=5BF0h
  6790. --------m-6759-------------------------------
  6791. INT 67 - LIM EMS 4.0 - GET EXPANDED MEMORY HARDWARE INFORMATION
  6792.     AH = 59h
  6793.     AL = subfunction
  6794.         00h get hardware configuration array
  6795.         ES:DI -> buffer to be filled with array (see #03655)
  6796.         01h get unallocated raw page count
  6797.         Return: BX = unallocated raw pages
  6798.             DX = total raw pages
  6799. Return: AH = status (see also AH=58h"EMS 4.0")
  6800.         A4h access denied by operating system
  6801. Note:    subfunction 00h is for use by operating systems only, and can be
  6802.       enabled or disabled at any time by the operating system
  6803.  
  6804. Format of EMS hardware configuration array:
  6805. Offset    Size    Description    (Table 03655)
  6806.  00h    WORD    size of raw EMM pages in paragraphs
  6807.  02h    WORD    number of alternate register sets
  6808.  04h    WORD    size of mapping-context save area in bytes
  6809.  06h    WORD    number of register sets assignable to DMA
  6810.  08h    WORD    DMA operation type
  6811.         0000h DMA with alternate register sets
  6812.         0001h only one DMA register set
  6813. --------m-675A-------------------------------
  6814. INT 67 - LIM EMS 4.0 - ALLOCATE STANDARD/RAW PAGES
  6815.     AH = 5Ah
  6816.     AL = subfunction
  6817.         00h allocate standard pages
  6818.         01h allocate raw pages
  6819.     BX = number of pages to allocate
  6820. Return: DX = handle
  6821.     AH = status (00h,80h,81h,84h,85h,87h,88h,8Fh) (see #03648)
  6822. --------m-675B-------------------------------
  6823. INT 67 - LIM EMS 4.0 - ALTERNATE MAP REGISTER SET
  6824.     AH = 5Bh
  6825.     AL = subfunction
  6826.         00h get alternate map register set
  6827.         Return: BL = current active alternate map register set number
  6828.             ES:DI -> map register context save area if BL=00h
  6829.         01h set alternate map register set
  6830.         BL = new alternate map register set number
  6831.         ES:DI -> map register context save area if BL=0
  6832.         02h get alternate map save array size
  6833.         Return: DX = array size in bytes
  6834.         03h allocate alternate map register set
  6835.         Return: BL = number of map register set; 00h = not supported
  6836.         04h deallocate alternate map register set
  6837.         BL = number of alternate map register set
  6838. Return: AH = status (00h,80h,81h,84h,8Fh,9Ah-9Dh,A3h,A4h) (see #03656)
  6839. Note:    this function is for use by operating systems only, and can be
  6840.       enabled or disabled at any time by the operating system
  6841.  
  6842. (Table 03656)
  6843. Values for EMS function status:
  6844.  00h    successful
  6845.  80h    internal error
  6846.  81h    hardware malfunction
  6847.  84h    undefined function requested
  6848.  8Fh    undefined subfunction
  6849.  9Ah    specified alternate map register or DMA register set not supported
  6850.  9Bh    all alternate map register or DMA register sets currently allocated
  6851.  9Ch    alternate map register or DMA register sets not supported
  6852.  9Dh    undefined or unallocated alternate map register/DMA register set
  6853.  9Eh    dedicated DMA channels not supported
  6854.  9Fh    specified dedicated DMA channel not supported
  6855.  A3h    source array corrupted
  6856.  A4h    operating system denied access
  6857. --------m-675B-------------------------------
  6858. INT 67 - LIM EMS 4.0 - ALTERNATE MAP REGISTER SET - DMA REGISTERS
  6859.     AH = 5Bh
  6860.     AL = subfunction
  6861.         05h allocate DMA register set
  6862.         Return: BL = DMA register set number, 00h if not supported
  6863.         06h enable DMA on alternate map register set
  6864.            BL = DMA register set number
  6865.            DL = DMA channel number
  6866.         07h disable DMA on alternate map register set
  6867.            BL = DMA register set number
  6868.         08h deallocate DMA register set
  6869.            BL = DMA register set number
  6870. Return: AH = status (00h,80h,81h,84h,8Fh,9Ah-9Fh,A3h,A4h) (see #03656)
  6871. Note:    this function is for use by operating systems only, and can be
  6872.       enabled or disabled at any time by the operating system
  6873. --------m-675BE0-----------------------------
  6874. INT 67 - MICEMM v4D, RM386 - GET LINEAR ADDRESS OF MEMORY
  6875.     AX = 5BE0h
  6876.     ES:BX -> memory for which to get linear address
  6877. Return: AH = 00h
  6878.     CX:DX = linear address of physical memory corresponding to ES:BX
  6879. Program: RAM-MAN/386 is the memory manager included with Helix's Netroom;
  6880.       MICEMM is a memory manager for some Micronics motherboards
  6881. Note:    this has been superceded by AX=DE06h, which should be used instead
  6882. SeeAlso: AX=5BF0h,AX=5BF1h,AX=DE06h
  6883. --------m-675BE1-----------------------------
  6884. INT 67 - RM386 v6.00+ - GET MEMORY MANAGER SIZE
  6885.     AX = 5BE1h
  6886. Return: AH = 00h
  6887.     CX = code and data size in bytes
  6888.     DX:BX = physical address of RM386 code
  6889.     DI:SI = total size of RM386 area including handle tables
  6890.     BP = number of additional pages (high DOS, etc.)
  6891. SeeAlso: AX=5BE0h,AX=5BE2h
  6892. --------m-675BE2-----------------------------
  6893. INT 67 - RM386 v6.00+ - GET INTERRUPT VECTORS
  6894.     AX = 5BE2h
  6895. Return: DS:SI -> V86-mode table (see #03657)
  6896.     ES:BX -> ??? (undoc, middle of device driver interrupt routine!)
  6897. SeeAlso: AX=5BE0h,AX=5BE1h
  6898.  
  6899. Format of RM386 V86-mode table:
  6900. Offset    Size    Description    (Table 03657)
  6901.  00h    DWORD    original INT 13 vector
  6902.  04h    DWORD    original INT 15 vector
  6903.  08h    DWORD    original INT 19 vector
  6904.  0Ch    DWORD    original INT 21 vector
  6905.  10h    DWORD    original INT 4B vector
  6906.  14h    DWORD    original INT 67 vector
  6907. --------m-675BF0-----------------------------
  6908. INT 67 - MICEMM v4D, RM386 - INSTALLATION CHECK
  6909.     AX = 5BF0h
  6910. Return: AH = 00h if MICEMM or RM386 present
  6911.         BX = code segment of driver
  6912. Program: MICEMM is the Micronics Expanded Memory Manager; RM386 is the memory
  6913.       manager included in Helix Software's Netroom
  6914. SeeAlso: AH=3Fh,AX=5BE0h,AX=5BF1h
  6915. --------m-675BF1-----------------------------
  6916. INT 67 - MICEMM v4D, RM386 - GET ADDRESS MAP
  6917.     AX = 5BF1h
  6918.     ES:BX -> 256-byte (MICEMM) or 512-byte (RM386) buffer for memory types
  6919. Return: AH = 00h
  6920.     ES:BX buffer filled (see #03658)
  6921. Note:    each byte in the buffer specifies the type of a 4K page of memory
  6922. SeeAlso: AX=5BE0h,AX=5BF0h
  6923.  
  6924. (Table 03658)
  6925. Values for MICEMM/RM386 memory type:
  6926.  00h    unused (MICEMM), RAM/available (RM386)
  6927.  02h    DOS extension (XMS UMB)
  6928.  04h    shadowed ROM
  6929.  08h    mappable EMS
  6930.  10h    page frame
  6931.  20h    ROM
  6932.  40h    reserved (video memory, etc)
  6933.  80h    RAM (MICEMM), Windows UMB (RM386)
  6934. --------m-675BF2-----------------------------
  6935. INT 67 - RM386 - GET RM386 INTERNAL DATA
  6936.     AX = 5BF2h
  6937.     CX = size of buffer
  6938.     DS:SI -> buffer for internal data
  6939.     (documentation says ES:BX -> buffer, SI = offset within RM386)
  6940. Return: buffer filled
  6941. Note:    the data returned by this function is release-specific
  6942. SeeAlso: AX=5BF0h
  6943. --------m-675BF3-----------------------------
  6944. INT 67 - RM386 - RETURN TO REAL MODE
  6945.     AX = 5BF3h
  6946. Return: nothing
  6947. Note:    use AX=5DE0h instead of this functin
  6948. SeeAlso: AX=5BF0h,AX=5DE0h
  6949. --------m-675BF4-----------------------------
  6950. INT 67 - RM386 v6.00 - GET RM386 GLOBAL FLAGS
  6951.     AX = 5BF4h
  6952. Return: AH = 00h
  6953.     BX = global flags 1 (see #03659)
  6954.     CX = global flags 2 (see #03660)
  6955.     DX = global flags 3 (see #03661)
  6956.     SI = global flags 4 (see #03662)
  6957. SeeAlso: AX=5BF0h
  6958.  
  6959. Bitfields for RM386 global flags 1:
  6960. Bit(s)    Description    (Table 03659)
  6961.  0-3    reserved
  6962.  4    V86 mode
  6963.  5    reserved
  6964.  6    80386 or higher CPU
  6965.  7,8    reserved
  6966.  9    A20 enabled at startup
  6967.  10    "HIGH_IO"
  6968.  11    ROM
  6969.  12    large frame
  6970.  13,14    reserved
  6971.  15    PS/2-style A20 control
  6972.  
  6973. Bitfields for RM386 global flags 2:
  6974. Bit(s)    Description    (Table 03660)
  6975.  0    HMA in use
  6976.  1    XMS present
  6977.  2    using XMS driver memory
  6978.  3    HIGH (NEAT only)
  6979.  4-7    reserved
  6980.  8    NOBKTRAP
  6981.  9    NORESET
  6982.  10    ALTMAP
  6983.  11    NOFRAME
  6984.  12-15    reserved
  6985.  
  6986. Bitfields for RM386 global flags 3:
  6987. Bit(s)    Description    (Table 03661)
  6988.  0    NOTEST
  6989.  1    NOEBDA
  6990.  2    Windows3 support
  6991.  3    system board mouse
  6992.  4    DISKBUF
  6993.  5    EBDALOW
  6994.  6    A20 global enable flag
  6995.  7    A20 flag
  6996.  8    EBDA moved to stub
  6997.  9    VXD file was found
  6998.  10    reserved
  6999.  11    NOBOOTMAP
  7000.  12    AUTO
  7001.  13    PS/2 machine
  7002.  14    Compaq ROM merge active
  7003.  15    NOHMA set
  7004.  
  7005. Bitfields for RM386 global flags 4:
  7006. Bit(s)    Description    (Table 03662)
  7007.  0    "NOV8259" don't virtualize interrupt controller
  7008.  1    NOSCSI
  7009.  2    NOSCAN
  7010.  3    NOTR
  7011.  4    ALTBOOT
  7012.  5    NOCOMPQ
  7013.  6    KB2TRAP
  7014.  7    DESHADOW
  7015.  8    Video 7 VGA detected
  7016.  9    reserved
  7017.  10    NOVGA
  7018.  11    NOPS2
  7019.  12    DEBUG
  7020.  13    NOVKB
  7021.  14,15    reserved
  7022. --------m-675BF5-----------------------------
  7023. INT 67 - RM386 v6.00 - GET RM386 EMS HANDLE COUNT
  7024.     AX = 5BF5h
  7025. Return: AH = status
  7026.         00h successful
  7027.         BX = current number of allocated EMS handles
  7028.         84h function not available
  7029. SeeAlso: AX=5BF0h
  7030. --------m-675C-------------------------------
  7031. INT 67 - LIM EMS 4.0 - PREPARE EXPANDED MEMORY HARDWARE FOR WARM BOOT
  7032.     AH = 5Ch
  7033. Return: AH = status (see #03663)
  7034. Note:    when MS-DOS v6.xx EMM386 is loaded and the keyboard driver supports
  7035.       INT 15/AH=4Fh (keyboard intercept) calls, the system may hang
  7036.       instead of booting if this function is called just prior to a jump
  7037.       to F000h:FFF0h
  7038.  
  7039. (Table 03663)
  7040. Values for EMS function status:
  7041.  00h    successful
  7042.  80h    internal error
  7043.  81h    hardware malfunction
  7044.  84h    undefined function requested
  7045. --------m-675D-------------------------------
  7046. INT 67 - LIM EMS 4.0 - ENABLE/DISABLE OS FUNCTION SET FUNCTIONS
  7047.     AH = 5Dh
  7048.     AL = subfunction
  7049.         00h enable OS Function Set
  7050.         01h disable OS Function Set
  7051.         02h return access key (resets memory manager, returns access key at
  7052.         next invocation)
  7053.     BX,CX = access key returned by first invocation
  7054. Return: BX,CX = access key, returned only on first invocation of function
  7055.     AH = status (see also AH=5Ch)
  7056.         8Fh undefined subfunction
  7057.         A4h operating system denied access
  7058. --------m-675D03-----------------------------
  7059. INT 67 u - Nanosoft MD386 - INTERNAL INITIALIZATION
  7060.     AX = 5D03h
  7061.     ???
  7062. Return: ???
  7063. Program: MD386 is a subset EMS memory manager by Nanosoft specifically
  7064.       designed for use with the MultiDOS Plus multitasker
  7065. SeeAlso: AX=5D04h,AX=5E00h
  7066. --------m-675D04-----------------------------
  7067. INT 67 - Nanosoft MD386 - GET ALTERNATE MAP STRUCTURE
  7068.     AX = 5D04h
  7069.     BX = alternate register set number
  7070.     ES:DI -> 1024-byte buffer for map structure
  7071. Return: AH = status (see #03648)
  7072.     buffer filled if AH=00h
  7073. Note:    used for debugging purposes
  7074. SeeAlso: AX=5D05h
  7075. --------m-675D05-----------------------------
  7076. INT 67 - Nanosoft MD386 - GET INTERNAL HANDLE TABLE
  7077.     AX = 5D05h
  7078.     BX = handle number
  7079.     ES:DI -> 1024-byte buffer for handle table
  7080. Return: AH = status (see #03648)
  7081.     buffer filled if AH=00h
  7082. Note:    used for debugging purposes
  7083. SeeAlso: AX=5D04h
  7084. --------m-675DE0-----------------------------
  7085. INT 67 - RM386 - DISABLE RM386
  7086.     AX = 5DE0h
  7087. Note:    RM386 traps this function on the initial transition to protected
  7088.       mode caused by the INT instruction, which means it can not be
  7089.       overridden simply by hooking the interrupt
  7090. SeeAlso: AX=5DE1h
  7091. --------m-675DE1-----------------------------
  7092. INT 67 - RM386 - ENABLE RM386
  7093.     AX = 5DE1h
  7094. Note:    RM386 traps this function on the initial transition to protected
  7095.       mode caused by the INT instruction, which means it can not be
  7096.       overridden simply by hooking the interrupt
  7097. SeeAlso: AX=5DE0h
  7098. --------m-675DE2-----------------------------
  7099. INT 67 - RM386 - GET PAGE TABLE
  7100.     AX = 5DE2h
  7101.     ES:DI -> 1088-byte buffer for page table
  7102. Return: ES:DI buffer filled
  7103. Note:    RM386 traps this function on the initial transition to protected
  7104.       mode caused by the INT instruction, which means it can not be
  7105.       overridden simply by hooking the interrupt
  7106. SeeAlso: AX=5DE3h
  7107. --------m-675DE3-----------------------------
  7108. INT 67 - RM386 - SET PAGE TABLE
  7109.     AX = 5DE3h
  7110.     ES:DI -> 1088-byte buffer containing page table
  7111. Notes:    only the access bits of the page table are used, the remainder is
  7112.       ignored
  7113.     RM386 traps this function on the initial transition to protected
  7114.       mode caused by the INT instruction, which means it can not be
  7115.       overridden simply by hooking the interrupt
  7116. SeeAlso: AX=5DE2h
  7117. --------m-675DE4-----------------------------
  7118. INT 67 - RM386 - SET WRITE-PROTECTION FOR PAGE IN FIRST MEGABYTE
  7119.     AX = 5DE4h
  7120.     BL = page number
  7121.     BH = access (00h read-only, 01h read-write)
  7122. Note:    RM386 traps this function on the initial transition to protected
  7123.       mode caused by the INT instruction, which means it can not be
  7124.       overridden simply by hooking the interrupt
  7125. --------m-675DE5-----------------------------
  7126. INT 67 - RM386 - MAP PHYSICAL PAGE TO PHYSICAL SEGMENT
  7127.     AX = 5DE5h
  7128.     EBX = physical page number
  7129.     DX = page number in first megabyte to be remapped (linear-addr SHR 12)
  7130. Return: AH = status
  7131.         00h successful
  7132.         8Bh invalid destination page (not in first megabyte)
  7133. Note:    RM386 traps this function on the initial transition to protected
  7134.       mode caused by the INT instruction, which means it can not be
  7135.       overridden simply by hooking the interrupt
  7136. SeeAlso: AX=5DE6h
  7137. --------m-675DE6-----------------------------
  7138. INT 67 - RM386 - MAP LOGICAL 4K PAGE TO PHYSICAL SEGMENT
  7139.     AX = 5DE6h
  7140.     BX = logical page number in 4K pages from beginning of memory for EMS
  7141.           handle
  7142.     CX = segment in first megabyte to be remapped
  7143.     DX = previously-allocated EMS handle
  7144. Return: AH = status
  7145.         00h successful
  7146.         83h invalid handle
  7147.         8Ah invalid logical page (out of handle's range)
  7148.         8Bh invalid destination page (not in first megabyte)
  7149. Note:    RM386 traps this function on the initial transition to protected
  7150.       mode caused by the INT instruction, which means it can not be
  7151.       overridden simply by hooking the interrupt
  7152. SeeAlso: AX=5DE5h
  7153. --------m-675DE7-----------------------------
  7154. INT 67 - RM386 - SET PAGE TABLE BITS FOR RANGE OF PAGES
  7155.     AX = 5DE7h
  7156.     BL = page table bits to be set (bits 2-0 = U/S, R/W, P)
  7157.     CX = number of pages to set
  7158.     DX = first page number to set (in first megabyte)
  7159. Return: AH = status
  7160.         00h successful
  7161.         8Bh invalid destination page (not in first megabyte)
  7162.         A5h invalid page bits
  7163.         A6h invalid page count (overflows first megabyte)
  7164. Note:    RM386 traps this function on the initial transition to protected
  7165.       mode caused by the INT instruction, which means it can not be
  7166.       overridden simply by hooking the interrupt
  7167. --------m-675DE8-----------------------------
  7168. INT 67 - RM386 - GET PARTIAL PAGE TABLE
  7169.     AX = 5DE8h
  7170.     BX = starting page number in first megabyte+HMA (0000h-010Fh)
  7171.     CX = number of page table entries to get
  7172.     ES:DI -> buffer for DWORD page table entries
  7173. Return: AH = status (00h successful, 8Bh invalid page)
  7174. Note:    RM386 traps this function on the initial transition to protected
  7175.       mode caused by the INT instruction, which means it can not be
  7176.       overridden simply by hooking the interrupt
  7177. SeeAlso: AX=5DE9h
  7178. --------m-675DE9-----------------------------
  7179. INT 67 - RM386 - SET PARTIAL PAGE TABLE
  7180.     AX = 5DE9h
  7181.     BX = starting page number in first megabyte+HMA (0000h-010Fh)
  7182.     CX = number of page table entries to get
  7183.     DS:SI -> buffer of DWORD page table entries
  7184. Return: AH = status (00h successful, 8Bh invalid destination page)
  7185. Note:    RM386 traps this function on the initial transition to protected
  7186.       mode caused by the INT instruction, which means it can not be
  7187.       overridden simply by hooking the interrupt
  7188. SeeAlso: AX=5DE8h
  7189. --------m-675DEA-----------------------------
  7190. INT 67 - RM386 - V86-MODE I/O PORT TRAPPING CONTROL
  7191.     AX = 5DEAh
  7192.     BX = function
  7193.         00h globally disable V86-mode trapping
  7194.         01h globally enable V86-mode trapping
  7195.         CL = interrupt to use for trapping
  7196.         02h get I/O trapping state
  7197. Return: AH = status
  7198.         00h successful
  7199.         BX = current trapping state (function 02h)
  7200.             0000h disabled, 0001h enabled
  7201.         CX = interrupt used as trap interrupt (functions 00h and 02h)
  7202. Notes:    RM386 traps this function on the initial transition to protected
  7203.       mode caused by the INT instruction, which means it can not be
  7204.       overridden simply by hooking the interrupt
  7205.     when I/O trapping is enabled and I/O port access occurs, RM386
  7206.       simulates an INT instruction for the specified interrupt; the
  7207.       interrupt handler is responsible for decoding the trapped instruction
  7208.       and performing the appropriate action.  INT 2C/AX=002Dh provides a
  7209.       similar but more-easily used interface.
  7210. SeeAlso: AX=5DEBh,AH=EFh"RM386",INT 2C/AX=002Dh
  7211. --------m-675DEB-----------------------------
  7212. INT 67 - RM386 - V86-MODE I/O TRAPPING PORT CONTROL
  7213.     AX = 5DEBh
  7214.     BX = function
  7215.         00h disable V86-mode trapping for specified port
  7216.         01h enable V86-mode trapping for specified port
  7217.         02h get V86-mode trapping state for specified port
  7218.     DX = port for which to enable/disable/query trapping
  7219. Return: AH = status
  7220.         00h successful
  7221.         BX = current trapping state (00h off, 01h on) (function 02)
  7222.         A7h invalid port ID
  7223.         A8h reserved port--cannot trap/untrap (DMA/INT/KBD controllers)
  7224. Notes:    RM386 traps this function on the initial transition to protected
  7225.       mode caused by the INT instruction, which means it can not be
  7226.       overridden simply by hooking the interrupt
  7227. SeeAlso: AX=5DEAh
  7228. --------m-675DFD-----------------------------
  7229. INT 67 U - RM386 v6.00 - ???
  7230.     AX = 5DFDh
  7231.     ???
  7232. Return: ???
  7233. Note:    RM386 traps this function on the initial transition to protected
  7234.       mode caused by the INT instruction, which means it can not be
  7235.       overridden simply by hooking the interrupt
  7236. SeeAlso: AX=5DFEh
  7237. --------m-675DFE-----------------------------
  7238. INT 67 U - RM386 v6.00 - ???
  7239.     AX = 5DFEh
  7240.     ???
  7241. Return: ???
  7242. Note:    RM386 traps this function on the initial transition to protected
  7243.       mode caused by the INT instruction, which means it can not be
  7244.       overridden simply by hooking the interrupt
  7245. SeeAlso: AX=5DFDh
  7246. --------m-675DFF-----------------------------
  7247. INT 67 U - RM386 v6.00 - ???
  7248.     AX = 5DFFh
  7249.     ???
  7250. Return: ???
  7251. Note:    RM386 traps this function on the initial transition to protected
  7252.       mode caused by the INT instruction, which means it can not be
  7253.       overridden simply by hooking the interrupt
  7254. SeeAlso: AX=5DFDh,AX=5DFEh
  7255. --------m-675E00-----------------------------
  7256. INT 67 - Nanosoft MD386 - SET HARDWARE BREAKPOINT
  7257.     AX = 5E00h
  7258.     DH = breakpoint number (0-3)
  7259.     DL = breakpoint attributes (used to set DR7)
  7260.     CX:BX = linear address of breakpoint
  7261. SeeAlso: AX=5D03h,AX=5E01h
  7262. --------m-675E01-----------------------------
  7263. INT 67 - Nanosoft MD386 - GET HARDWARE DEBUG REGISTER
  7264.     AX = 5E01h
  7265.     BL = register number (0-3,7)
  7266. Return: CX:BX = value of specified DRx register
  7267. SeeAlso: AX=5E00h
  7268. --------m-675E02-----------------------------
  7269. INT 67 - Nanosoft MD386 - SET DEBUG EXCEPTION HANDLER
  7270.     AX = 5E02h
  7271.     CX:BX -> exception handler
  7272. Note:    the specified exception handler is called with a simulated interrupt
  7273.       whenever a debug exception occurs which was caused by a hardware
  7274.       breakpoint set with the debug registers
  7275. SeeAlso: AX=5E04h,AX=5E05h
  7276. --------m-675E03-----------------------------
  7277. INT 67 - Nanosoft MD386 - ENABLE/DISABLE MEMORY WRITE PROTECTION
  7278.     AX = 5E03h
  7279.     BL = register map set number
  7280.     BH = new state (00h read-only, else read-write)
  7281.     CX = linear page number (linear address SHR 12)
  7282. Note:    setting write protection in map set 0 will cause the setting to become
  7283.       the default for newly-allocated map sets
  7284. --------m-675E04-----------------------------
  7285. INT 67 - Nanosoft MD386 - GET DEBUG EXCEPTION
  7286.     AX = 5E04h
  7287. Return: BL = debug exception (low byte of DR6 register)
  7288. SeeAlso: AX=5E02h,AX=5E05h
  7289. --------m-675E05-----------------------------
  7290. INT 67 - Nanosoft MD386 - IGNORE NEXT DEBUG EXCEPTION
  7291.     AX = 5E05h
  7292. Note:    may be required when using AX=5E02h for handling instruction
  7293.       breakpoints
  7294. SeeAlso: AX=5E02h,AX=5E04h
  7295. --------m-6760-------------------------------
  7296. INT 67 - EEMS - GET PHYSICAL WINDOW ARRAY
  7297.     AH = 60h
  7298.     ES:DI -> buffer
  7299. Return: AH = status (see also AH=40h)
  7300.     AL = number of entries
  7301.     buffer at ES:DI filled
  7302. --------m-6761-------------------------------
  7303. INT 67 - EEMS - GENERIC ACCELERATOR CARD SUPPORT
  7304.     AH = 61h
  7305.     ???
  7306. Return: ???
  7307. Note:    can be used by accelerator card manufacturer to flush RAM cache,
  7308.       ensuring that the cache accurately reflects what the processor would
  7309.       see without the cache.
  7310. --------m-676100-----------------------------
  7311. INT 67 - EEMS - STB GENERIC ACCELERATOR CARD SUPPORT - INSTALLATION CHECK???
  7312.     AX = 6100h
  7313. Return: AH = status (00h if installed???)
  7314. Note:    STB's RAPIDMAP.SYS EMS driver calls this function and AX=6101h if
  7315.       the signature "GACXXX" is found at offset 0Ah in the INT 67 handler's
  7316.       segment (i.e. a device driver named GACXXX?? has hooked INT 67)
  7317. SeeAlso: AX=6101h,INT 02/SI=0714h
  7318. --------m-676101-----------------------------
  7319. INT 67 - EEMS - STB GENERIC ACCELERATOR CARD SUPPORT - GET ??? ENTRY POINT
  7320.     AX = 6101h
  7321. Return: AH = status
  7322.     ---if AH=00h---
  7323.     ES:BX -> ??? entry point
  7324. SeeAlso: AX=6100h
  7325. --------m-6768-------------------------------
  7326. INT 67 - EEMS - GET ADDRESSES OF ALL PAGE FRAMES IN SYSTEM
  7327.     AH = 68h
  7328.     ES:DI -> buffer
  7329. Return: AH = status (see also AH=40h)
  7330.     AL = number of entries
  7331.     buffer at ES:DI filled
  7332. Note:    equivalent to LIM 4.0 function 58h
  7333. --------m-6769-------------------------------
  7334. INT 67 - EEMS - MAP PAGE INTO FRAME
  7335.     AH = 69h
  7336.     AL = frame number
  7337.     BX = page number
  7338.     DX = handle
  7339. Return: AH = status (see also AH=40h)
  7340. Note:    similar to EMS function 44h
  7341. SeeAlso: AH=44h,AH=50h,AH=6Ah
  7342. --------m-676A-------------------------------
  7343. INT 67 - EEMS - PAGE MAPPING
  7344.     AH = 6Ah
  7345.     AL = subfunction
  7346.         00h save partial page map
  7347.         CH = first page frame
  7348.         CL = number of frames
  7349.         ES:DI -> buffer which is to be filled
  7350.         01h restore partial page map
  7351.         CH = first page frame
  7352.         CL = number of frames
  7353.         DI:SI -> previously saved page map
  7354.         02h save and restore partial page map
  7355.         CH = first page frame
  7356.         CL = number of frames
  7357.         ES:DI = buffer for current page map
  7358.         DI:SI = new page map
  7359.         03h get size of save array
  7360.         CH = first page frame
  7361.         CL = number of frames
  7362.         Return: AL = size of array in bytes
  7363.         04h switch to standard map register setting
  7364.         05h switch to alternate map register setting
  7365.         06h deallocate pages mapped to frames in conventional memory
  7366.         CH = first page frame
  7367.         CL = number of frames
  7368. Return: AH = status (see #03648)
  7369. Note:    similar to EMS function 4Eh, except that a subrange of pages can be
  7370.       specified
  7371. SeeAlso: AH=69h
  7372. --------m-676B-------------------------------
  7373. INT 67 - DESQview 2.42-2.53 - BUG
  7374.     AH = 6Bh
  7375. Note:    the EMM.DVR portion of DESQview branches to a random location on this
  7376.       function due to a fencepost error
  7377. --------m-67DD-------------------------------
  7378. INT 67 - Quadtel QMAPS - API
  7379.     AH = DDh
  7380.     AL = function
  7381.     ???
  7382. Return: ???
  7383. Notes:    details are not yet available
  7384.     Hewlett-Packard's HPMM.SYS is a licensed version of QMAPS, and thus
  7385.       supports this API
  7386. SeeAlso: AH=3Fh,AX=FFA5h
  7387. --------E-67DE00-----------------------------
  7388. INT 67 - Virtual Control Program Interface - INSTALLATION CHECK
  7389.     AX = DE00h
  7390. Return: AH = status
  7391.         00h VCPI is present
  7392.         BH = major version number
  7393.         BL = minor version number
  7394.         nonzero  VCPI not present
  7395. BUG:    MS Windows 3.00 is reported to "object violently" to this call.
  7396. SeeAlso: INT 2F/AX=1687h
  7397. --------E-67DE01-----------------------------
  7398. INT 67 - Virtual Control Program Interface - GET PROTECTED MODE INTERFACE
  7399.     AX = DE01h
  7400.     ES:DI -> 4K page table buffer
  7401.     DS:SI -> three descriptor table entries in GDT
  7402.         first becomes code segment descriptor, other two for use by
  7403.           main control program
  7404. Return: AH = 00h successful
  7405.         DI -> first unused page table entry in buffer
  7406.         EBX -> protected mode entry point in code segment (see #03664)
  7407.     AH = nonzero  failed
  7408. Note:    protected mode entry point may be called with AX=DE00h-DE05h and
  7409.       AX=DE0Ch (in each case, all other registers as appropriate for
  7410.       the function)
  7411. SeeAlso: INT 2F/AX=1687h,INT 67/AH=3Fh
  7412.  
  7413. (Table 03664)
  7414. Call QEMM v6.03 protected mode entry point additionally with:
  7415.     AX = DF00h ???
  7416.         ???
  7417.         Return: ???
  7418.     AX = DF01h ???
  7419.         ???
  7420.         Return: ???
  7421. --------E-67DE02-----------------------------
  7422. INT 67 - Virtual Control Program Interface - GET MAX PHYSICAL MEMORY ADDRESS
  7423.     AX = DE02h
  7424. Return: AH = 00h  successful
  7425.         EDX = physical address of highest 4K memory page
  7426.     AH nonzero: failed
  7427. SeeAlso: AH=3Fh
  7428. --------E-67DE03-----------------------------
  7429. INT 67 - Virtual Control Program Interface - GET NUMBER OF FREE 4K PAGES
  7430.     AX = DE03h
  7431. Return: AH = 00h  successful
  7432.         EDX = number of free 4K pages
  7433.     AH nonzero: failed
  7434. Notes:    returns total number of pages available to ALL tasks in system
  7435.     also available in protected mode by calling the protected-mode VCPI
  7436.       entry point (see AX=DE01h,#03664)
  7437. SeeAlso: AX=DE04h
  7438. --------E-67DE04-----------------------------
  7439. INT 67 - Virtual Control Program Interface - ALLOCATE A 4K PAGE
  7440.     AX = DE04h
  7441. Return: AH = 00h successful
  7442.         EDX = physical address of allocated page
  7443.     AH nonzero: failed
  7444. Notes:    the client program is responsible for freeing all memory allocated
  7445.       with this call before terminating
  7446.     also available in protected mode by calling the protected-mode VCPI
  7447.       entry point (see AX=DE01h,#03664)
  7448. SeeAlso: AH=3Fh,AX=DE03h,AX=DE05h
  7449. --------E-67DE05-----------------------------
  7450. INT 67 - Virtual Control Program Interface - FREE 4K PAGE
  7451.     AX = DE05h
  7452.     EDX = physical address of 4K page
  7453. Return: AH = status
  7454.         00h successful
  7455.         nonzero failed
  7456. Note:    also available in protected mode by calling the protected-mode VCPI
  7457.       entry point (see AX=DE01h,#03664)
  7458. SeeAlso: AH=3Fh,AX=DE04h
  7459. --------E-67DE06-----------------------------
  7460. INT 67 - Virtual Control Program Interface - GET PHYS ADDR OF PAGE IN FIRST MB
  7461.     AX = DE06h
  7462.     CX = page number (linear address shifted right 12 bits)
  7463. Return: AH = status
  7464.         00h successful
  7465.         EDX = physical address of page
  7466.         nonzero invalid page number (AH = 8Bh recommended)
  7467. SeeAlso: AX=5BE0h
  7468. --------E-67DE07-----------------------------
  7469. INT 67 - Virtual Control Program Interface - READ CR0
  7470.     AX = DE07h
  7471. Return: AH = 00h
  7472.     EBX = value of Control Register 0
  7473. SeeAlso: AH=3Fh,AX=DE07h
  7474. --------E-67DE08-----------------------------
  7475. INT 67 - Virtual Control Program Interface - READ DEBUG REGISTERS
  7476.     AX = DE08h
  7477.     ES:DI -> array of 8 DWORDs
  7478. Return: AH = 00h
  7479.     buffer filled with DR0 first, DR7 last, DR4 and DR5 unused
  7480. SeeAlso: AH=3Fh,AX=DE09h
  7481. --------E-67DE09-----------------------------
  7482. INT 67 - Virtual Control Program Interface - SET DEBUG REGISTERS
  7483.     AX = DE09h
  7484.     ES:DI -> array of 8 DWORDs holding new values of debug registers
  7485. Return: AH = 00h
  7486. Note:    values for DR4 and DR5 ignored
  7487. SeeAlso: AH=3Fh,AX=DE08h
  7488. --------E-67DE0A-----------------------------
  7489. INT 67 - Virtual Control Program Interface - GET 8259 INTERRUPT VECTOR MAPPINGS
  7490.     AX = DE0Ah
  7491. Return: AH = 00h successful
  7492.         BX = first vector used by master 8259 (IRQ0)
  7493.         CX = first vector used by slave 8259 (IRQ8)
  7494.     AH nonzero: failed
  7495. Note:    CX is undefined in systems without a slave 8259
  7496. SeeAlso: AX=DE0Bh,INT 21/AX=250Ch,INT 31/AX=0400h
  7497. --------E-67DE0B-----------------------------
  7498. INT 67 - Virtual Control Program Interface - SET 8259 INTERRUPT VECTOR MAPPINGS
  7499.     AX = DE0Bh
  7500.     BX = first vector used by master 8259
  7501.     CX = first vector used by slave 8259
  7502.     interrupts disabled
  7503. Return: AH = 00h successful
  7504.     AH nonzero: failed
  7505. Notes:    This call merely informs the server that the client has changed the
  7506.       interrupt mappings.  The client may not change the mappings if they
  7507.       have already been changed by the server or another client, and is
  7508.       responsible for restoring the original mappings before terminating.
  7509. SeeAlso: AX=DE0Ah,INT 2C/AX=002Ah
  7510. --------E-67DE0C-----------------------------
  7511. INT 67 - Virtual Control Program Interface - SWITCH TO PROTECTED MODE
  7512.     AX = DE0Ch
  7513.     ESI = linear address in first megabyte of values for system
  7514.           registers (see #03665)
  7515.     interrupts disabled
  7516. Return: interrupts disabled
  7517.     GDTR, IDTR, LDTR, TR loaded
  7518.     SS:ESP must have at least 16 bytes space, and the entry point is
  7519.           required to set up a new stack before enabling interrupts
  7520.     EAX, ESI, DS, ES, FS, GS destroyed
  7521. Note:    in protected mode, calling the protected-mode VCPI entry point with
  7522.       AX = DE0Ch
  7523.       DS = segment selector mapping entire linear address space obtained
  7524.           via AX=DE01h
  7525.       SS:ESP in first megabyte of linear memory
  7526.       STACK:QWORD  return address from FAR call to 32-bit segment
  7527.         DWORD  EIP
  7528.         DWORD  CS
  7529.         DWORD  reserved for EFLAGS
  7530.         DWORD  ESP
  7531.         DWORD  SS
  7532.         DWORD  ES
  7533.         DWORD  DS
  7534.         DWORD  FS
  7535.         DWORD  GS
  7536.       and interrupts disabled, will switch to virtual86 mode with
  7537.         interrupts disabled, all segment registers loaded, and EAX
  7538.         destroyed.
  7539. SeeAlso: AH=3Fh,INT 15/AH=89h,INT D4/AH=10h
  7540.  
  7541. Format of system register values for switch to protected mode:
  7542. Offset    Size    Description    (Table 03665)
  7543.  00h    DWORD    value for CR3
  7544.  04h    DWORD    linear address in first megabyte of value for GDTR
  7545.  08h    DWORD    linear address in first megabyte of value for IDTR
  7546.  0Ch    WORD    value for LDTR
  7547.  0Eh    WORD    value for TR
  7548.  10h    PWORD    CS:EIP of protected mode entry-point
  7549. --------m-67DE0F-----------------------------
  7550. INT 67 - Netroom3 - ???
  7551.     AX = DE0Fh
  7552.     ???
  7553. Return: ???
  7554. Note:    called by Netroom's DPMI.EXE
  7555. --------m-67EF-------------------------------
  7556. INT 67 - RM386 v6.00+ - EXECUTE XMS FUNCTION
  7557.     AH = EFh
  7558.     AL = function (00h-12h,80h-8Fh)
  7559.     other register as appropriate for XMS function
  7560. Return: varies by function (see INT 2F/AX=4310h"XMS")
  7561. Note:    these functions appear to be equivalent to the XMS functions with the
  7562.       same numbers
  7563. SeeAlso: AX=5DFFh"RM386",INT 2F/AX=4310h"XMS"
  7564. --------m-67FFA5-----------------------------
  7565. INT 67 - Microsoft EMM386.EXE v4.20+ - INSTALLATION CHECK
  7566.     AX = FFA5h
  7567. Return: AX = 845Ah/84A5h if loaded
  7568.         BX:CX -> API entry point (see #03666)
  7569. Notes:    this call is available even if EMM386 is not providing EMS
  7570.     the returned AX is 845Ah inside of MSWindows, 84A5h under bare DOS
  7571.     if no other program has hooked INT 67, an alternate installation
  7572.       check is to test for the string
  7573.       "MICROSOFT EXPANDED MEMORY MANAGER 386" at offset 14h in the INT 67
  7574.       handler's segment; the word immediately preceding this string
  7575.       contains the offset of the API entry point
  7576. SeeAlso: AH=3Fh,AX=FFA5h/BX=4345h,INT 21/AX=4402h"EMM386.EXE"
  7577.  
  7578. (Table 03666)
  7579. Call EMM386.EXE API entry point with:
  7580.     AH = 00h get memory manager's status
  7581.         Return: AH = status
  7582.             bit 0: not active (OFF)
  7583.             bit 1: in "Auto" mode
  7584.     AH = 01h set memory manager's state
  7585.         AL = new state (00h ON, 01h OFF, 02h AUTO)
  7586.     AH = 02h Weitek coprocessor support
  7587.         AL = subfunction
  7588.         00h get Weitek support state
  7589.             Return: AL = status
  7590.                 bit 0: Weitek coprocessor is present
  7591.                 bit 1: Weitek support is enabled
  7592.         01h turn on Weitek support
  7593.         02h turn off Weitek support
  7594.      --- v4.20-4.41 only ---
  7595.     AH = 03h Windows support???
  7596.         AL = subfunction (00h, 01h)
  7597.     AH = 04h print copyright notice to standard output
  7598.          (using INT 21/AH=09h)
  7599.     AH = 05h print available report
  7600.          (the one shown when running EMM386 from the DOS prompt)
  7601. SeeAlso: #01513 at INT 21/AX=4402h/SF=02h,#02617 at INT 2F/AX=12FFh/BX=0106h
  7602. --------m-67FFA5BX4345-----------------------
  7603. INT 67 U - Compaq CEMM v5.10+ - PRIVATE API
  7604.     AX = FFA5h
  7605.     BX = 4345h ("CE")
  7606.     DX = subfunction
  7607.         0000h unshadow video ROM???
  7608.         0001h shadow video ROM???
  7609.         0002h map pages
  7610.         CX = number of pages (00h=one)
  7611.         ESI = linear address of first page to map into address space
  7612.         EDI = linear starting address at which pages are to be visible
  7613.         0003h get ???
  7614.         Return: DX = ??? (0-2)
  7615.         0004h BUG: crashes system due to fencepost error
  7616. Return: AH = 84h
  7617.     AL = status (84h = error, FFh = success)
  7618. Note:    if BX <> 4345h or DX > 0004h on entry, CEMM behaves identically to
  7619.       Microsoft's EMM386 (see AX=FFA5h"EMM386")
  7620. SeeAlso: AX=FFA5h"EMM386",#01513 at INT 21/AX=4402h/SF=02h,#03666
  7621. --------I-68---------------------------------
  7622. INT 68 - Sangoma CCPOP 3270 resident module
  7623. SeeAlso: INT 67"Sangoma",INT 92"Sangoma"
  7624. --------N-68---------------------------------
  7625. INT 68 - Novell NetWare LU6.2
  7626. InstallCheck:    test for the signature string "APPC/PC" nine bytes before the
  7627.       interrupt handler
  7628. SeeAlso: AH=01h/SF=1B00h,AH=FAh
  7629. --------h-68---------------------------------
  7630. INT 68 C - HP Vectra AT - IRQ16 - 8041 SERVICE REQUEST
  7631. SeeAlso: INT 08"IRQ0",INT 69"HP Vectra",INT 6F/AH=00h"HP"
  7632. --------N-6801--SF1B00-----------------------
  7633. INT 68 - APPC/PC - NETWORK DEVICE CONTROL - DISPLAY
  7634.     AH = 01h subfn 1B00h
  7635.     DS:DX -> control block (see #03667)
  7636. Return: control block updated
  7637. SeeAlso: AH=01h/SF=2000h,AH=01h/SF=2B00h,INT 68"Novell"
  7638.  
  7639. Format of APPC/PC "DISPLAY" control block:
  7640. Offset    Size    Description    (Table 03667)
  7641.  00h 12 BYTEs    reserved
  7642.  0Ch    WORD    1B00h (verb "DISPLAY")
  7643.  0Eh  6 BYTEs    00h
  7644.  14h    DWORD    (big-endian) return code (see #03668)
  7645.  18h    WORD    00h
  7646.  1Ah  8 BYTEs    (big-endian) logical unit ID
  7647.  22h  8 BYTEs    (big-endian) partner logical unit name
  7648.  2Ah  8 BYTEs    (big-endian) mode name
  7649.  32h    BYTE    logical unit session limit
  7650.  33h    BYTE    partner logical unit session limit
  7651.  34h    BYTE    node maximum negotiable session limit
  7652.  35h    BYTE    current session limit
  7653.  36h    BYTE    minimum negotiated winner limit
  7654.  37h    BYTE    maximum negotiated loser limit
  7655.  38h    BYTE    active session count
  7656.  39h    BYTE    active CONWINNER session count
  7657.  3Ah    BYTE    active CONLOSER session count
  7658.  3Bh    BYTE    session termination count
  7659.  3Ch    BYTE    bit 7: SESSION_TERMINATION_TARGET_DRAIN
  7660.         bit 6: SESSION_TERMINATION_SOURCE_DRAIN
  7661.  
  7662. (Table 03668)
  7663. Values for APPC/PC return code:
  7664.  0000h    successful
  7665.  0001h    BAD_TP_ID
  7666.  0002h    BAD_CONV_ID
  7667.  0003h    bad logical unit ID
  7668.  0008h    no physical unit attached
  7669.  0110h    bad state
  7670.  01B1h    BAD_PART_LUNAME
  7671.  01B2h    bad mode name
  7672.  0201h    physical unit already active
  7673.  0211h    logical unit already active
  7674.  0212h    BAD_PART_SESS
  7675.  0213h    BAD_RU_SIZES
  7676.  0214h    BAD_MODE_SESS
  7677.  0216h    BAD_PACING_CNT
  7678.  0219h    EXTREME_RUS
  7679.  021Ah    SNASVCMG_1
  7680.  0223h    SSCP_CONNECTED_LU
  7681.  0230h    invalid change
  7682.  0243h    too many TPs
  7683.  0272h    adapter close failure
  7684.  0281h    GET_ALLOC_BAD_TYPE
  7685.  0282h    unsuccessful
  7686.  0283h    DLC failure
  7687.  0284h    unrecognized DLC
  7688.  0286h    duplicate DLC
  7689.  0301h    SSCP_PU_SESSION_NOT_ACTIVE
  7690.  0302h    data exceeds RU size
  7691.  0401h    invalid direction
  7692.  0402h    invalid type
  7693.  0403h    segment overlap
  7694.  0404h    invalid first character
  7695.  0405h    table error
  7696.  0406h    conversion error
  7697.  F0010000h    APPC disabled
  7698.  F0020000h    APPC busy
  7699.  F0030000h    APPC abended
  7700.  F0040000h    incomplete
  7701. --------N-6801--SF2000-----------------------
  7702. INT 68 - APPC/PC - NETWORK DEVICE CONTROL - ATTACH PHYSICAL UNIT
  7703.     AH = 01h subfn 2000h
  7704.     DS:DX -> control block (see #03669)
  7705. Return: control block updated
  7706. SeeAlso: AH=01h/SF=2100h,AH=01h/SF=2B00h
  7707.  
  7708. Format of APPC/PC "Attach Physical Unit" control block:
  7709. Offset    Size    Description    (Table 03669)
  7710.  00h 12 BYTEs    reserved
  7711.  0Ch    WORD    2000h (verb "Attach Physical Unit")
  7712.  0Eh  6 BYTEs    00h
  7713.  14h    DWORD    (big-endian) return code (see #03668)
  7714.  18h    WORD    00h
  7715.  1Ah    BYTE    version
  7716.  1Bh    BYTE    release
  7717.  1Ch  8 BYTEs    (big-endian) net name
  7718.  24h  8 BYTEs    (big-endian) physical unit name
  7719.  2Ch  8 BYTEs    00h
  7720.  34h    DWORD    pointer to SYSTEM_LOG_EXIT routine, FFFFFFFFh=don't log errors
  7721.         (see also AH=01h/SF=2100h)
  7722.  38h    DWORD    00h
  7723.  3Ch    BYTE    00h RETURN_CONTROL: COMPLETE
  7724.         01h RETURN_CONTROL: INCOMPLETE
  7725. --------N-6801--SF2100-----------------------
  7726. INT 68 - APPC/PC - NETWORK DEVICE CONTROL - ATTACH LOGICAL UNIT
  7727.     AH = 01h subfn 2100h
  7728.     DS:DX -> control block (see #03670)
  7729. Return: control block updated
  7730. SeeAlso: #03673,#03674,#03676,AH=01h/SF=2000h,AH=01h/SF=2200h,AH=01h/SF=2B00h
  7731.  
  7732. Format of APPC/PC "Attach Logical Unit" control block:
  7733. Offset    Size    Description    (Table 03670)
  7734.  00h 12 BYTEs    reserved
  7735.  0Ch    WORD    2100h (verb "Attach Logical Unit")
  7736.  0Eh  6 BYTEs    00h
  7737.  14h    DWORD    (big-endian) return code (see #03668)
  7738.  18h    WORD    70  offset to partner logical unit record
  7739.  1Ah  8 BYTEs    (big-endian) logical unit name
  7740.  22h  8 BYTEs    (big-endian) logical unit ID
  7741.  2Ah    BYTE    logical unit local address
  7742.  2Bh    BYTE    logical unit session limit
  7743.  2Ch    DWORD    pointer to CREATE_TP_EXIT routine,
  7744.         FFFFFFFFh = reject incoming ALLOCATEs
  7745.         00000000h = queue ALLOCATEs
  7746.  30h    DWORD    00h
  7747.  34h    DWORD    pointer to SYSTEM_LOG_EXIT routine, FFFFFFFFh=don't log errors
  7748.  38h    DWORD    00h
  7749.  3Ch    BYTE    maximum TPs
  7750.  3Dh    BYTE    queue depth
  7751.  3Eh    DWORD    pointer to LU_LU_PASSWORD_EXIT routine, FFFFFFFFh=no pswd exit
  7752.  42h    DWORD    00h
  7753.  46h    WORD    total length of partner records
  7754.  48h    var    array of partner logical unit records (see #03671)
  7755. SeeAlso: #03673,#03674,#03676
  7756.  
  7757. Format of APPC/PC partner logical unit record:
  7758. Offset    Size    Description    (Table 03671)
  7759.  00h    WORD    length of this partner logical unit record
  7760.  02h    WORD    42  offset to mode records
  7761.  04h  8 BYTEs    (big-endian) partner logical unit name
  7762.  0Ch    BYTE    partner logical unit security capabilities
  7763.         bit 7: already verified
  7764.         bit 6: conversation level security
  7765.         bit 5: session level security
  7766.  0Dh    BYTE    partner logical unit session limit
  7767.  0Eh    WORD    partner logical unit maximum MC_SEND_LL
  7768.  10h  8 BYTEs    (big-endian) partner logical unit DLC name
  7769.  18h    BYTE    partner logical unit adapter number
  7770.  19h 17 BYTEs    (counted string) partner logical unit adapter address
  7771.  2Ah    WORD    total length of mode records
  7772.  2Ch 16N BYTEs    array of mode records (see #03672)
  7773.  
  7774. Format of mode record:
  7775. Offset    Size    Description    (Table 03672)
  7776.  00h    WORD    16  length of this mode record
  7777.  02h  8 BYTEs    (big-endian) mode name
  7778.  0Ah    WORD    RU_SIZE high bound
  7779.  0Ch    WORD    RU_SIZE low bound
  7780.  0Eh    BYTE    mode maximum negotiable session limit
  7781.  0Fh    BYTE    pacing size for receive
  7782.  
  7783. Routines defined by LU_LU_PASSWORD_EXIT, CREATE_TP_EXIT, and SYSTEM_LOG_EXIT
  7784. pointers are called by pushing the DWORD pointer to the verb on the stack and
  7785. then performing a FAR call.
  7786.  
  7787. Format of ACCESS_LU_LU_PW verb:
  7788. Offset    Size    Description    (Table 03673)
  7789.  00h 12 BYTEs    reserved
  7790.  0Ch    WORD    1900h (verb "ACCESS_LU_LU_PW")
  7791.  0Eh  8 BYTEs    (big-endian) logical unit ID
  7792.  16h  8 BYTEs    (big-endian) logical unit name
  7793.  1Eh  8 BYTEs    (big-endian) partner logical unit name
  7794.  26h 17 BYTEs    (counted string) partner fully qualified logical unit name
  7795.  37h    BYTE    password available (0=no, 1=yes)
  7796.  38h  8 BYTEs    password
  7797. SeeAlso: #03670,#03674,#03676
  7798.  
  7799. Format of CREATE_TP verb:
  7800. Offset    Size    Description    (Table 03674)
  7801.  00h 12 BYTEs    reserved
  7802.  0Ch    WORD    2300h (verb "CREATE_TP")
  7803.  0Eh  6 BYTEs    00h
  7804.  14h    DWORD    (big-endian) sense code (see #03675)
  7805.  18h  8 BYTEs    (big-endian) TP ID
  7806.  20h  8 BYTEs    (big-endian) logical unit ID
  7807.  28h    DWORD    (big-endian) conversation ID
  7808.  2Ch    BYTE    0 basic conversation, 1 mapped conversation
  7809.  2Dh    BYTE    0 no sync level, 1 confirm
  7810.  2Eh    BYTE    reserved
  7811.  2Fh 65 BYTEs    (counted string) transaction program name
  7812.  70h  6 BYTEs    00h
  7813.  76h    WORD    length of ERROR_LOG_DATA to return
  7814.  78h    DWORD    pointer to ERROR_LOG_DATA buffer
  7815.  7Ch  8 BYTEs    (big-endian) partner logical unit name
  7816.  84h 18 BYTEs    (counted string) partner fully qualified logical unit name
  7817.  96h  8 BYTEs    (big-endian) mode name
  7818.  9Eh 12 BYTEs    00h
  7819.  AAh 11 BYTEs    (counted string) password
  7820.  B5h 11 BYTEs    (counted string) user ID
  7821.  C0h    BYTE    0 verification should be performed
  7822.         1 already verified
  7823. SeeAlso: #03673,#03676
  7824.  
  7825. (Table 03675)
  7826. Values for APPC/PC sense code:
  7827.  00000000h    Ok
  7828.  080F6051h    SECURITY_NOT_VALID
  7829.  084B6031h    TP_NOT_AVAIL_RETRY
  7830.  084C0000h    TP_NOT_AVAIL_NO_RETRY
  7831.  10086021h    TP_NAME_NOT_RECOGNIZED
  7832.  10086034h    CONVERSATION_TYPE_MISMATCH
  7833.  10086041h    SYNC_LEVEL_NOT_SUPPORTED
  7834.  
  7835. Format of SYSLOG verb:
  7836. Offset    Size    Description    (Table 03676)
  7837.  00h 12 BYTEs    reserved
  7838.  0Ch    WORD    2600h (verb "SYSLOG")
  7839.  0Eh 10 BYTEs    00h
  7840.  18h    WORD    (big-endian) type
  7841.  1Ah    DWORD    (big-endian) subtype
  7842.  1Eh    DWORD    pointer to ADDITIONAL_INFO
  7843.  22h    DWORD    (big-endian) conversation ID
  7844.  26h  8 BYTEs    (big-endian) TP ID
  7845.  2Eh  8 BYTEs    (big-endian) physical unit or logical unit name
  7846.  36h    WORD    length of data
  7847.  38h    DWORD    pointer to data
  7848.  3Ch    BYTE    00h
  7849. SeeAlso: #03673,#03674
  7850. --------N-6801--SF2200-----------------------
  7851. INT 68 - APPC/PC - NETWORK DEVICE CONTROL - DETACH LOGICAL UNIT
  7852.     AH = 01h subfn 2200h
  7853.     DS:DX -> control block (see #03677)
  7854. Return: control block updated
  7855. SeeAlso: AH=01h/SF=2000h,AH=01h/SF=2100h,AH=01h/SF=2700h
  7856.  
  7857. Format of APPC/PC "Detach Logical Unit" control block:
  7858. Offset    Size    Description    (Table 03677)
  7859.  00h 12 BYTEs    reserved
  7860.  0Ch    WORD    2200h (verb "Detach Logical Unit")
  7861.  0Eh  6 BYTEs    00h
  7862.  14h    DWORD    (big-endian) return code (see #03668)
  7863.  18h  8 BYTEs    (big-endian) logical unit ID
  7864.  20h    BYTE    00h
  7865. --------N-6801--SF2700-----------------------
  7866. INT 68 - APPC/PC - NETWORK DEVICE CONTROL - DETACH PHYSICAL UNIT
  7867.     AH = 01h subfn 2700h
  7868.     DS:DX -> control block (see #03678)
  7869. Return: control block updated
  7870. SeeAlso: AH=01h/SF=2000h,AH=01h/SF=2100h,AH=01h/SF=2200h
  7871.  
  7872. Format of APPC/PC "Detach Physical Unit" control block:
  7873. Offset    Size    Description    (Table 03678)
  7874.  00h 12 BYTEs    reserved
  7875.  0Ch    WORD    2700h (verb "Detach Physical Unit")
  7876.  0Eh  6 BYTEs    00h
  7877.  14h    DWORD    (big-endian) return code (see #03668)
  7878.  18h    BYTE    00h  type: hard
  7879.         01h  type: soft
  7880. --------N-6801--SF2B00-----------------------
  7881. INT 68 - APPC/PC - NETWORK DEVICE CONTROL - ACTIVATE DLC
  7882.     AH = 01h subfn 2B00h
  7883.     DS:DX -> control block (see #03679)
  7884. Return: control block updated
  7885. SeeAlso: AH=01h/SF=1B00h,AH=01h/SF=2000h
  7886.  
  7887. Format of APPC/PC "Activate DLC" control block:
  7888. Offset    Size    Description    (Table 03679)
  7889.  00h 12 BYTEs    reserved
  7890.  0Ch    WORD    2B00h (verb "Activate DLC")
  7891.  0Eh  6 BYTEs    00h
  7892.  14h    DWORD    (big-endian) return code (see #03668)
  7893.  18h  8 BYTEs    (big-endian) DLC name
  7894.  20h    BYTE    adapter number
  7895. --------N-6802--SF0100-----------------------
  7896. INT 68 - APPC/PC - CONNECTION CONTROL - ALLOCATE
  7897.     AH = 02h subfn 0100h
  7898.     DS:DX -> control block (see #03680)
  7899. Return: control block updated
  7900. SeeAlso: AH=02h/SF=0500h
  7901.  
  7902. Format of APPC/PC "Allocate" control block:
  7903. Offset    Size    Description    (Table 03680)
  7904.  00h 12 BYTEs    reserved
  7905.  0Ch    WORD    0100h (verb "Allocate" or "MC_Allocate")
  7906.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  7907.         0 if basic verb
  7908.  0Fh  5 BYTEs    reserved (0)
  7909.  14h    WORD    (big-endian) primary return code (see #03681)
  7910.  16h    DWORD    (big-endian) error code (see #03682)
  7911.  1Ah  8 BYTEs    (big-endian) TP_ID
  7912.  22h    DWORD    (big-endian) conversation ID
  7913.  26h    BYTE    (MC_Allocate only) conversation type
  7914.         0 basic conversation
  7915.         1 mapped conversation
  7916.  27h    BYTE    SYNC_LEVEL (00h none, 01h confirm)
  7917.  28h    WORD    0000h
  7918.  2Ah    BYTE    RETURN_CONTROL
  7919.         00h when session allocated
  7920.         01h immediate
  7921.         02h when session free
  7922.  2Bh  8 BYTEs    00h
  7923.  33h  8 BYTEs    (big-endian) partner logical unit name
  7924.  3Bh  8 BYTEs    (big-endian) mode name
  7925.  43h 65 BYTEs    (counted string) TP name
  7926.  84h    BYTE    security (00h none, 01h same, 02h pgm)
  7927.  85h 11 BYTEs    00h
  7928.  90h 11 BYTEs    (counted string) password
  7929.  9Bh 11 BYTEs    (counted string) user ID
  7930.  A6h    WORD    PIP_DATA length
  7931.  A8h    DWORD    pointer to PIP_DATA
  7932.  
  7933. (Table 03681)
  7934. Values for APPC/PC primary return code:
  7935.  0000h    successful
  7936.  0001h    parameter check
  7937.  0002h    state check
  7938.  0003h    allocation error
  7939.  0005h    deallocate abended
  7940.  0006h    deallocate abended program
  7941.  0007h    deallocate abended SVC
  7942.  0008h    deallocate abended timer
  7943.  0009h    deallocate normal return
  7944.  000Ah    data posting blocked
  7945.  000Bh    posting not active
  7946.  000Ch    PROG_ERROR_NO_TRUNC
  7947.  000Dh    PROG_ERROR_TRUNC
  7948.  000Eh    PROG_ERROR_PURGING
  7949.  000Fh    CONV_FAILURE_RETRY
  7950.  0010h    CONV_FAILURE_NO_RETRY
  7951.  0011h    SVC_ERROR_NO_TRUNC
  7952.  0012h    SVC_ERROR_TRUNC
  7953.  0013h    SVC_ERROR_PURGING
  7954.  0014h    unsuccessful
  7955.  0018h    CNOS partner logical unit reject
  7956.  0019h    conversation type mixed
  7957.  F001h    APPC disabled
  7958.  F002h    APPC busy
  7959.  F003h    APPC abended
  7960.  F004h    incomplete
  7961.  
  7962. (Table 03682)
  7963. Values for APPC/PC error code:
  7964.  0001h    bad TP ID
  7965.  0002h    bad conversation ID
  7966.  0004h    allocation error, no retry
  7967.  0005h    allocation error, retry
  7968.  0006h    data area crosses segment boundary
  7969.  0010h    bad TPN length
  7970.  0011h    bad CONV length
  7971.  0012h    bad SYNC level
  7972.  0013h    bad security selection
  7973.  0014h    bad return control
  7974.  0015h    SEC_TOKENS too big
  7975.  0016h    PIP_LEN incorrect
  7976.  0017h    no use of SNASVCMG
  7977.  0018h    unknown partner mode
  7978.  0031h    confirm: SYNC_NONE
  7979.  0032h    confirm: bad state
  7980.  0033h    confirm: NOT_LL_BDY
  7981.  0041h    confirmed: bad state
  7982.  0051h    deallocate: bad type
  7983.  0052h    deallocate: flush bad state
  7984.  0053h    deallocate: confirm bad state
  7985.  0055h    deallocate: NOT_LL_BDY
  7986.  0057h    deallocate: log LL_WRONG
  7987.  0061h    flush: not send state
  7988.  0091h    post on receipt: invalid length
  7989.  0092h    post on receipt: not in receive state
  7990.  0093h    post on receipt: bad fill
  7991.  00A1h    prepare to receive:invalid type
  7992.  00A2h    prepare to receive: unfinished LL
  7993.  00A3h    prepare to receive: not in send state
  7994.  00B1h    receive and wait: bad state
  7995.  00B2h    receive and wait: NOT_LL_BDY
  7996.  00B5h    receive and wait: bad fill
  7997.  00C1h    receive immediate: not in receive state
  7998.  00C4h    receive immediate: bad fill
  7999.  00E1h    request to send: not in receive state
  8000.  00F1h    send data: bad LL
  8001.  00F2h    send data: not in send state
  8002.  0102h    send error: log LL wrong
  8003.  0103h    send error: bad type
  8004.  0121h    test: invalid type
  8005.  0122h    test: not in receive state
  8006. --------N-6802--SF0300-----------------------
  8007. INT 68 - APPC/PC - CONNECTION CONTROL - CONFIRM
  8008.     AH = 02h subfn 0300h
  8009.     DS:DX -> control block (see #03683)
  8010. Return: control block updated
  8011. SeeAlso: AH=02h/SF=0400h
  8012.  
  8013. Format of APPC/PC "Confirm" control block:
  8014. Offset    Size    Description    (Table 03683)
  8015.  00h 12 BYTEs    reserved
  8016.  0Ch    WORD    0300h (verb "Confirm" or "MC_Confirm")
  8017.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8018.         0 if basic verb
  8019.  0Fh  5 BYTEs    reserved (0)
  8020.  14h    WORD    (big-endian) primary return code (see #03681)
  8021.  16h    DWORD    (big-endian) error code (see #03682)
  8022.  1Ah  8 BYTEs    (big-endian) TP_ID
  8023.  22h    DWORD    (big-endian) conversation ID
  8024.  26h    BYTE    request to send received (0=no, 1=yes)
  8025. --------N-6802--SF0400-----------------------
  8026. INT 68 - APPC/PC - CONNECTION CONTROL - CONFIRMED
  8027.     AH = 02h subfn 0400h
  8028.     DS:DX -> control block (see #03684)
  8029. Return: control block updated
  8030. SeeAlso: AH=02h/SF=0300h
  8031.  
  8032. Format of APPC/PC "Confirmed" control block:
  8033. Offset    Size    Description    (Table 03684)
  8034.  00h 12 BYTEs    reserved
  8035.  0Ch    WORD    0400h (verb "Confirmed" or "MC_Confirmed")
  8036.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8037.         0 if basic verb
  8038.  0Fh  5 BYTEs    reserved (0)
  8039.  14h    WORD    (big-endian) primary return code (see #03681)
  8040.  16h    DWORD    (big-endian) error code (see #03682)
  8041.  1Ah  8 BYTEs    (big-endian) TP_ID
  8042.  22h    DWORD    (big-endian) conversation ID
  8043. --------N-6802--SF0500-----------------------
  8044. INT 68 - APPC/PC - CONNECTION CONTROL - DEALLOCATE
  8045.     AH = 02h subfn 0500h
  8046.     DS:DX -> control block (see #03685)
  8047. Return: control block updated
  8048. SeeAlso: AH=02h/SF=0100h,AH=02h/SF=0300h
  8049.  
  8050. Format of APPC/PC "Deallocate" control block:
  8051. Offset    Size    Description    (Table 03685)
  8052.  00h 12 BYTEs    reserved
  8053.  0Ch    WORD    0500h (verb "Deallocate" or "MC_Deallocate")
  8054.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8055.         0 if basic verb
  8056.  0Fh  5 BYTEs    reserved (0)
  8057.  14h    WORD    (big-endian) primary return code (see #03681)
  8058.  16h    DWORD    (big-endian) error code (see #03682)
  8059.  1Ah  8 BYTEs    (big-endian) TP_ID
  8060.  22h    DWORD    (big-endian) conversation ID
  8061.  26h    BYTE    00h
  8062.  27h    BYTE    type
  8063.         00h SYNC_LEVEL
  8064.         01h FLUSH
  8065.         02h ABEND_PROC
  8066.         03h ABEND_SVC
  8067.         04h ABEND_TIMER
  8068.         05h ABEND
  8069.  28h    WORD    (MC_Deallocate only) length of error log data
  8070.  2Ah    DWORD    (MC_Deallocate only) pointer to error log data
  8071. --------N-6802--SF0600-----------------------
  8072. INT 68 - APPC/PC - CONNECTION CONTROL - FLUSH
  8073.     AH = 02h subfn 0600h
  8074.     DS:DX -> control block (see #03686)
  8075. Return: control block updated
  8076. SeeAlso: AH=02h/SF=0300h
  8077.  
  8078. Format of APPC/PC "Flush" control block:
  8079. Offset    Size    Description    (Table 03686)
  8080.  00h 12 BYTEs    reserved
  8081.  0Ch    WORD    0600h (verb "Flush" or "MC_Flush")
  8082.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8083.         0 if basic verb
  8084.  0Fh  5 BYTEs    reserved (0)
  8085.  14h    WORD    (big-endian) primary return code (see #03681)
  8086.  16h    DWORD    (big-endian) error code (see #03682)
  8087.  1Ah  8 BYTEs    (big-endian) TP_ID
  8088.  22h    DWORD    (big-endian) conversation ID
  8089. --------N-6802--SF0700-----------------------
  8090. INT 68 - APPC/PC - CONNECTION CONTROL - GET ATTRIBUTES
  8091.     AH = 02h subfn 0700h
  8092.     DS:DX -> control block (see #03687)
  8093. Return: control block updated
  8094. SeeAlso: AH=02h/SF=0300h
  8095.  
  8096. Format of APPC/PC "Get_Attributes" control block:
  8097. Offset    Size    Description    (Table 03687)
  8098.  00h 12 BYTEs    reserved
  8099.  0Ch    WORD    0700h (verb "Get_Attributes" or "MC_Get_Attributes")
  8100.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8101.         0 if basic verb
  8102.  0Fh  5 BYTEs    reserved (0)
  8103.  14h    WORD    (big-endian) primary return code (see #03681)
  8104.  16h    DWORD    (big-endian) error code (see #03682)
  8105.  1Ah  8 BYTEs    (big-endian) TP_ID
  8106.  22h    DWORD    (big-endian) conversation ID
  8107.  26h  8 BYTEs    (big-endian) logical unit ID
  8108.  2Eh    BYTE    00h
  8109.  2Fh    BYTE    SYNC_LEVEL (0=none, 1=confirm)
  8110.  30h  8 BYTEs    (big-endian) mode name
  8111.  38h  8 BYTEs    (big-endian) own net name
  8112.  40h  8 BYTEs    (big-endian) own logical unit name
  8113.  48h  8 BYTEs    (big-endian) partner logical unit name
  8114.  50h 18 BYTEs    (counted string) partner's fully qualified logical unit name
  8115.  62h    BYTE    00h
  8116.  63h 11 BYTEs    (counted string) user ID
  8117. --------N-6802--SF0800-----------------------
  8118. INT 68 - APPC/PC - CONNECTION CONTROL - GET CONVERSATION TYPE
  8119.     AH = 02h subfn 0800h
  8120.     DS:DX -> control block (see #03688)
  8121. Return: control block updated
  8122. SeeAlso: AH=02h/SF=0300h
  8123.  
  8124. Format of APPC/PC "Get_Type" control block:
  8125. Offset    Size    Description    (Table 03688)
  8126.  00h 12 BYTEs    reserved
  8127.  0Ch    WORD    0800h (verb "Get_Type")
  8128.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8129.         0 if basic verb
  8130.  0Fh  5 BYTEs    reserved (0)
  8131.  14h    WORD    (big-endian) primary return code (see #03681)
  8132.  16h    DWORD    (big-endian) error code (see #03682)
  8133.  1Ah  8 BYTEs    (big-endian) TP_ID
  8134.  22h    DWORD    (big-endian) conversation ID
  8135.  26h    BYTE    (ret) type (0=basic conversation, 1=mapped conversation)
  8136. --------N-6802--SF0900-----------------------
  8137. INT 68 - APPC/PC - CONNECTION CONTROL - POST ON RECEIPT
  8138.     AH = 02h subfn 0900h
  8139.     DS:DX -> control block (see #03689)
  8140. Return: control block updated
  8141. SeeAlso: AH=02h/SF=0A00h
  8142.  
  8143. Format of APPC/PC "Post_on_Receipt" control block:
  8144. Offset    Size    Description    (Table 03689)
  8145.  00h 12 BYTEs    reserved
  8146.  0Ch    WORD    0900h (verb "Post_on_Receipt")
  8147.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8148.         0 if basic verb
  8149.  0Fh  5 BYTEs    reserved (0)
  8150.  14h    WORD    (big-endian) primary return code (see #03681)
  8151.  16h    DWORD    (big-endian) error code (see #03682)
  8152.  1Ah  8 BYTEs    (big-endian) TP_ID
  8153.  22h    DWORD    (big-endian) conversation ID
  8154.  26h    WORD    maximum length
  8155.  28h    BYTE    fill (0=buffer, 1=LL)
  8156. --------N-6802--SF0A00-----------------------
  8157. INT 68 - APPC/PC - CONNECTION CONTROL - PREPARE TO RECEIVE
  8158.     AH = 02h subfn 0A00h
  8159.     DS:DX -> control block (see #03690)
  8160. Return: control block updated
  8161. SeeAlso: AH=02h/SF=0900h,AH=02h/SF=0B00h
  8162.  
  8163. Format of APPC/PC "Prepare_to_Receive" control block:
  8164. Offset    Size    Description    (Table 03690)
  8165.  00h 12 BYTEs    reserved
  8166.  0Ch    WORD    0A00h (verb "Prepare_to_Receive" or "MC_Prepare_to_Receive")
  8167.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8168.         0 if basic verb
  8169.  0Fh  5 BYTEs    reserved (0)
  8170.  14h    WORD    (big-endian) primary return code (see #03681)
  8171.  16h    DWORD    (big-endian) error code (see #03682)
  8172.  1Ah  8 BYTEs    (big-endian) TP_ID
  8173.  22h    DWORD    (big-endian) conversation ID
  8174.  26h    BYTE    type (0=SYNC_LEVEL, 1=FLUSH)
  8175.  27h    BYTE    locks (0=short, 1=long)
  8176. --------N-6802--SF0B00-----------------------
  8177. INT 68 - APPC/PC - CONNECTION CONTROL - RECEIVE AND WAIT
  8178.     AH = 02h subfn 0B00h
  8179.     DS:DX -> control block (see #03691)
  8180. Return: control block updated
  8181. SeeAlso: AH=02h/SF=0C00h,AH=02h/SF=0F00h
  8182.  
  8183. Format of APPC/PC "Receive_and_Wait" control block:
  8184. Offset    Size    Description    (Table 03691)
  8185.  00h 12 BYTEs    reserved
  8186.  0Ch    WORD    0B00h (verb "Receive_and_Wait" or "MC_Receive_and_Wait")
  8187.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8188.         0 if basic verb
  8189.  0Fh  5 BYTEs    reserved (0)
  8190.  14h    WORD    (big-endian) primary return code (see #03681)
  8191.  16h    DWORD    (big-endian) error code (see #03682)
  8192.  1Ah  8 BYTEs    (big-endian) TP_ID
  8193.  22h    DWORD    (big-endian) conversation ID
  8194.  26h    BYTE    type of information received (see #03692)
  8195.  27h    BYTE    (MC_Receive_and_Wait only) fill (0=buffer, 1=LL)
  8196.  28h    BYTE    Request_to_Send_Received (0=no, 1=yes)
  8197.  29h    WORD    maximum length
  8198.  2Bh    WORD    data length
  8199.  2Dh    DWORD    pointer to data
  8200.  
  8201. (Table 03692)
  8202. Values for type of information received:
  8203.  00h    data
  8204.  01h    data complete
  8205.  02h    data incomplete
  8206.  03h    confirm
  8207.  04h    confirm send
  8208.  05h    confirm deallocate
  8209.  06h    send
  8210. --------N-6802--SF0C00-----------------------
  8211. INT 68 - APPC/PC - CONNECTION CONTROL - RECEIVE IMMEDIATE
  8212.     AH = 02h subfn 0C00h
  8213.     DS:DX -> control block (see #03693)
  8214. Return: control block updated
  8215. SeeAlso: AH=02h/SF=0B00h,AH=02h/SF=0F00h
  8216.  
  8217. Format of APPC/PC "Receive_Immediate" control block:
  8218. Offset    Size    Description    (Table 03693)
  8219.  00h 12 BYTEs    reserved
  8220.  0Ch    WORD    0C00h (verb "Receive_Immediate" or "MC_Receive_Immediate")
  8221.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8222.         0 if basic verb
  8223.  0Fh  5 BYTEs    reserved (0)
  8224.  14h    WORD    (big-endian) primary return code (see #03681)
  8225.  16h    DWORD    (big-endian) error code (see #03682)
  8226.  1Ah  8 BYTEs    (big-endian) TP_ID
  8227.  22h    DWORD    (big-endian) conversation ID
  8228.  26h    BYTE    type of information received (see #03692)
  8229.  27h    BYTE    (MC_Receive_Immediate only) fill (0=buffer, 1=LL)
  8230.  28h    BYTE    Request_to_Send_Received (0=no, 1=yes)
  8231.  29h    WORD    maximum length
  8232.  2Bh    WORD    data length
  8233.  2Dh    DWORD    pointer to data
  8234. --------N-6802--SF0E00-----------------------
  8235. INT 68 - APPC/PC - CONNECTION CONTROL - REQUEST TO SEND
  8236.     AH = 02h subfn 0E00h
  8237.     DS:DX -> control block (see #03694)
  8238. Return: control block updated
  8239. SeeAlso: AH=02h/SF=0F00h,AH=02h/SF=1000h
  8240.  
  8241. Format of APPC/PC "Request_to_Send" control block:
  8242. Offset    Size    Description    (Table 03694)
  8243.  00h 12 BYTEs    reserved
  8244.  0Ch    WORD    0E00h (verb "Request_to_Send" or "MC_Request_to_Send")
  8245.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8246.         0 if basic verb
  8247.  0Fh  5 BYTEs    reserved (0)
  8248.  14h    WORD    (big-endian) primary return code (see #03681)
  8249.  16h    DWORD    (big-endian) error code (see #03682)
  8250.  1Ah  8 BYTEs    (big-endian) TP_ID
  8251.  22h    DWORD    (big-endian) conversation ID
  8252. --------N-6802--SF0F00-----------------------
  8253. INT 68 - APPC/PC - CONNECTION CONTROL - SEND DATA
  8254.     AH = 02h subfn 0F00h
  8255.     DS:DX -> control block (see #03695)
  8256. Return: control block updated
  8257. SeeAlso: AH=02h/SF=0E00h,AH=02h/SF=1000h
  8258.  
  8259. Format of APPC/PC "Send_Data" control block:
  8260. Offset    Size    Description    (Table 03695)
  8261.  00h 12 BYTEs    reserved
  8262.  0Ch    WORD    0F00h (verb "Send_Data" or "MC_Send_Data")
  8263.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8264.         0 if basic verb
  8265.  0Fh  5 BYTEs    reserved (0)
  8266.  14h    WORD    (big-endian) primary return code (see #03681)
  8267.  16h    DWORD    (big-endian) error code (see #03682)
  8268.  1Ah  8 BYTEs    (big-endian) TP_ID
  8269.  22h    DWORD    (big-endian) conversation ID
  8270.  26h    BYTE    request to send received (0=no, 1=yes)
  8271.  27h    BYTE    00h
  8272.  28h    WORD    data length
  8273.  2Ah    DWORD    pointer to data
  8274. --------N-6802--SF1000-----------------------
  8275. INT 68 - APPC/PC - CONNECTION CONTROL - SEND ERROR
  8276.     AH = 02h subfn 1000h
  8277.     DS:DX -> control block (see #03696)
  8278. Return: control block updated
  8279. SeeAlso: AH=02h/SF=0F00h
  8280.  
  8281. Format of APPC/PC "Send_Error" control block:
  8282. Offset    Size    Description    (Table 03696)
  8283.  00h 12 BYTEs    reserved
  8284.  0Ch    WORD    1000h (verb "Send_Error" or "MC_Send_Error")
  8285.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8286.         0 if basic verb
  8287.  0Fh  5 BYTEs    reserved (0)
  8288.  14h    WORD    (big-endian) primary return code (see #03681)
  8289.  16h    DWORD    (big-endian) error code (see #03682)
  8290.  1Ah  8 BYTEs    (big-endian) TP_ID
  8291.  22h    DWORD    (big-endian) conversation ID
  8292.  26h    BYTE    request to send received (0=no, 1=yes)
  8293.  27h    BYTE    type (0=program, 1=SVC)
  8294.  28h    DWORD    00h
  8295.  2Ch    WORD    (MC_Send_Error only) LOG_DATA length
  8296.  2Eh    DWORD    (MC_Send_Error only) pointer to LOG_DATA
  8297. --------N-6802--SF1200-----------------------
  8298. INT 68 - APPC/PC - CONNECTION CONTROL - TEST
  8299.     AH = 02h subfn 1200h
  8300.     DS:DX -> control block (see #03697)
  8301. Return: control block updated
  8302. SeeAlso: AH=02h/SF=1300h
  8303.  
  8304. Format of APPC/PC "Test" control block:
  8305. Offset    Size    Description    (Table 03697)
  8306.  00h 12 BYTEs    reserved
  8307.  0Ch    WORD    1200h (verb "Test" or "MC_Test")
  8308.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8309.         0 if basic verb
  8310.  0Fh  5 BYTEs    reserved (0)
  8311.  14h    WORD    (big-endian) primary return code (see #03681)
  8312.  16h    DWORD    (big-endian) error code (see #03682)
  8313.  1Ah  8 BYTEs    (big-endian) TP_ID
  8314.  22h    DWORD    (big-endian) conversation ID
  8315.  26h    BYTE    (MC_Test only) test (0=posted, 1=request_to_send received)
  8316. Note:    error code has different interpretations for:
  8317.     0 posted data
  8318.     1 posted not data (primary return code = 0)
  8319.     1 bad TP_ID (primary return code = 1)
  8320. --------N-6802--SF1300-----------------------
  8321. INT 68 - APPC/PC - CONNECTION CONTROL - WAIT
  8322.     AH = 02h subfn 1300h
  8323.     DS:DX -> control block (see #03698)
  8324. Return: control block updated
  8325. SeeAlso: AH=02h/SF=1200h
  8326.  
  8327. Format of APPC/PC "Wait" control block:
  8328. Offset    Size    Description    (Table 03698)
  8329.  00h 12 BYTEs    reserved
  8330.  0Ch    WORD    1300h (verb "Wait")
  8331.  0Eh    BYTE    1 if MC_ (mapped conversation) form of verb
  8332.         0 if basic verb
  8333.  0Fh  5 BYTEs    reserved (0)
  8334.  14h    WORD    (big-endian) primary return code (see #03681)
  8335.  16h    DWORD    (big-endian) error code (see #03682,#03697)
  8336.  1Ah  8 BYTEs    (big-endian) TP_ID
  8337.  22h    DWORD    (big-endian) conversation ID
  8338.  26h    BYTE    number of conversations to wait on
  8339.         Note: error codes have interpretations as for AH=02h/SF=1200h
  8340. --------N-6803--SF2400-----------------------
  8341. INT 68 - APPC/PC - TP STARTED
  8342.     AH = 03h subfn 2400h
  8343.     DS:DX -> control block (see #03699)
  8344. Return: control block updated
  8345.  
  8346. Format of APPC/PC "TP Started" control block:
  8347. Offset    Size    Description    (Table 03699)
  8348.  00h 12 BYTEs    reserved
  8349.  0Ch    WORD    2400h (verb "TP Started")
  8350.  0Eh  6 BYTEs    00h
  8351.  14h    DWORD    (big-endian) return code (see #03668)
  8352.  18h    WORD    00h
  8353.  1Ah  8 BYTEs    (big-endian) logical unit ID
  8354.  22h  8 BYTEs    (big-endian) TP ID
  8355. --------N-6803--SF2800-----------------------
  8356. INT 68 - APPC/PC - GET ALLOCATE
  8357.     AH = 03h subfn 2800h
  8358.     DS:DX -> control block (see #03700)
  8359. Return: control block updated
  8360.  
  8361. Format of APPC/PC "Get ALLOCATE" control block:
  8362. Offset    Size    Description    (Table 03700)
  8363.  00h 12 BYTEs    reserved
  8364.  0Ch    WORD    2800h (verb "Get ALLOCATE")
  8365.  0Eh  6 BYTEs    00h
  8366.  14h    DWORD    (big-endian) return code (see #03668)
  8367.  18h    WORD    00h
  8368.  1Ah  8 BYTEs    (big-endian) logical unit ID
  8369.  22h    BYTE    type (00h dequeue, 01h test)
  8370.  23h    DWORD    pointer to CREATE_TP record
  8371. --------N-6803--SF2A00-----------------------
  8372. INT 68 - APPC/PC - CHANGE LOGICAL UNIT
  8373.     AH = 03h subfn 2A00h
  8374.     DS:DX -> control block (see #03701)
  8375. Return: control block updated
  8376.  
  8377. Format of APPC/PC "Change Logical Unit" control block:
  8378. Offset    Size    Description    (Table 03701)
  8379.  00h 12 BYTEs    reserved
  8380.  0Ch    WORD    2A00h (verb "Change Logical Unit")
  8381.  0Eh  6 BYTEs    00h
  8382.  14h    DWORD    (big-endian) return code (see #03668)
  8383.  18h    WORD    00h
  8384.  1Ah  8 BYTEs    (big-endian) logical unit ID
  8385.  22h    DWORD    pointer to CREATE_TP_EXIT routine
  8386.         00000000h queue ALLOCATEs
  8387.         FFFFFFFFh reject incoming ALLOCATEs
  8388.  26h    DWORD    00000000h
  8389.  2Ah    DWORD    pointer to SYSTEM_LOG_EXIT routine, FFFFFFFFh= don't log errors
  8390.  2Eh    DWORD    00000000h
  8391.  32h    BYTE    maximum TPs
  8392.  33h    BYTE    00h stop QUEUE_ALLOCATEs
  8393.         01h resume QUEUE_ALLOCATEs
  8394.  34h    DWORD    pointer to LU_LU_PASSWORD_EXIT routine, FFFFFFFFh = no exit
  8395.  38h    DWORD    00000000h
  8396. --------N-6804-------------------------------
  8397. INT 68 - APPC/PC - TRANSACTION PROCESSING
  8398.     AH = 04h
  8399.     DS:DX -> control block (see #03702)
  8400. Return: control block updated
  8401.  
  8402. Format of APPC/PC control block:
  8403. Offset    Size    Description    (Table 03702)
  8404.  00h 12 BYTEs    reserved
  8405.  0Ch    WORD    verb (action)
  8406.         2500h TP_ENDED
  8407.         2900h TP_VALID
  8408.  0Eh  6 BYTEs    00h
  8409.  14h    DWORD    (big-endian) return code (see #03668)
  8410.  18h    WORD    00h
  8411.  1Ah  8 BYTEs    (big-endian) TP_ID
  8412.  22h    DWORD    -> CREATE_TP record (only if verb = 2900h)
  8413. --------N-6805-------------------------------
  8414. INT 68 - APPC/PC - TRANSFER MESSAGE DATA
  8415.     AH = 05h
  8416.     DS:DX -> control block (see #03703)
  8417. Return: control block updated
  8418.  
  8419. Format of APPC/PC "Transfer Message Data" control block:
  8420. Offset    Size    Description    (Table 03703)
  8421.  00h 12 BYTEs    reserved
  8422.  0Ch    WORD    1C00h (verb "Transfer Message Data")
  8423.  0Eh    BYTE    data type
  8424.         00h user defined
  8425.         01h NMVT
  8426.         02h alert subvectors
  8427.         03h PDSTATS subvectors
  8428.  0Fh  5 BYTEs    00h
  8429.  14h    DWORD    (big-endian) return code (see #03668)
  8430.  18h 12 BYTEs    00h
  8431.  24h    BYTE    flags (see #03704)
  8432.  25h    BYTE    00h
  8433.  26h    WORD    length of data
  8434.  28h  N BYTEs    data
  8435.  
  8436. Bitfields for APPC/PC message transfer flags:
  8437. Bit(s)    Description    (Table 03704)
  8438.  0    don't add correlation subvector
  8439.  1    don't add product set ID subvector
  8440.  2    don't do SYSLOG
  8441.  3    don't send SSCP_PU_SESSION
  8442. SeeAlso: #03703
  8443. --------N-6806-------------------------------
  8444. INT 68 - APPC/PC - CHANGE NUMBER OF SESSIONS
  8445.     AH = 06h
  8446.     DS:DX -> control block (see #03705)
  8447. Return: control block updated
  8448.  
  8449. Format of APPC/PC "Change Number of Sessions" control block:
  8450. Offset    Size    Description    (Table 03705)
  8451.  00h 12 BYTEs    reserved
  8452.  0Ch    WORD    1500h (verb "Change Number of Sessions")
  8453.  0Eh  6 BYTEs    00h
  8454.  14h    WORD    (big-endian) primary return code (see #03681)
  8455.  16h    DWORD    (big-endian) secondary return code (see #03668,#03706)
  8456.  1Ah  8 BYTEs    (big-endian) logical unit ID
  8457.  22h  8 BYTEs    blanks
  8458.  2Ah  8 BYTEs    (big-endian) partner logical unit name
  8459.  32h  8 BYTEs    (big-endian) mode name
  8460.  3Ah    BYTE    bit 7: use MODE_NAME_SELECT_ALL rather than MODE_NAME
  8461.         bit 6: set negotiable values
  8462.  3Bh    BYTE    partner logical unit mode session limit
  8463.  3Ch    BYTE    minimum CONWINNERS_SOURCE
  8464.  3Dh    BYTE    maximum CONWINNERS_TARGET
  8465.  3Eh    BYTE    automatic activation
  8466.  3Fh    BYTE    00h
  8467.  40h    BYTE    flags
  8468.         bit 7: drain target
  8469.         bit 6: drain source
  8470.         bit 5: target responsible, not source
  8471.  
  8472. (Table 03706)
  8473. Values for secondary return code (see also AH=01h/SF=1B00h):
  8474.  0000h    accepted
  8475.  0001h    negotiated
  8476.  0003h    bad logical unit ID
  8477.  0004h    allocation failure, no retry
  8478.  0005h    allocation failure, retry
  8479.  0151h    can't raise limits
  8480.  0153h    all modes must reset
  8481.  0154h    bad SNASVCMG limits
  8482.  0155h    minimum greater than total
  8483.  0156h    mode closed (primary return code = 1)
  8484.     CNOS mode closed (primary return code = 18h)
  8485.  0157h    bad mode name (primary return code = 1)
  8486.     CNOS bad mode name (primary return code = 18h)
  8487.  0159h    reset SNA drains
  8488.  015Ah    single not SRC response
  8489.  015Bh    bad partner logical unit
  8490.  015Ch    exceeds maximum allowed
  8491.  015Dh    change SRC drains
  8492.  015Eh    logical unit detached
  8493.  015Fh    CNOS command race reject
  8494. --------N-6807-------------------------------
  8495. INT 68 - APPC/PC - PASSTHROUGH
  8496.     AH = 07h
  8497.     DS:DX -> control block (format depends on application subsystem)
  8498. Return: control block updated
  8499. SeeAlso: AH=FFh
  8500. ----------684300-----------------------------
  8501. INT 68 U - ??? - INSTALLATION CHECK???
  8502.     AX = 4300h
  8503. Return: AX = F386h if ???
  8504.     ???
  8505. Note:    called by Novell DOS 7.0 EMM386.EXE
  8506. SeeAlso: AX=4400h,INT 41/AX=004Fh
  8507. ----------684400-----------------------------
  8508. INT 68 U - ???
  8509.     AX = 4400h
  8510.     BX = ???
  8511.     CX = ???
  8512.     DX = ???
  8513.     DS:SI = real-mode address of protected-mode GDT
  8514.     ES:DI = real-mode address of protected-mode IDT
  8515. Return: ???
  8516. Note:    called by Novell DOS 7.0 EMM386.EXE if AX=4300h returns AX=F386h
  8517. SeeAlso: AX=4300h
  8518. --------W-6847-------------------------------
  8519. INT 68 - MS Windows debugging kernel - OUTPUT STRING
  8520.     AH = 47h
  8521.     ES:SI -> string
  8522. Notes:    output a string (to inform a debugger of some events)
  8523.     KERNEL outputs "Windows Kernel Entry\r\n" on startup
  8524. SeeAlso: INT 41/AX=0012h
  8525. --------N-68FA-------------------------------
  8526. INT 68 - APPC/PC - ENABLE/DISABLE APPC
  8527.     AH = FAh
  8528.     AL bit 0 = new state (0 enable, 1 disable)
  8529. SeeAlso: AH=FDh,INT 68"Novell"
  8530. --------N-68FB-------------------------------
  8531. INT 68 - APPC/PC - CONVERT
  8532.     AH = FBh
  8533.     DS:DX -> control block (see #03707)
  8534. Return: control block updated
  8535.  
  8536. Format of APPC/PC "CONVERT" control block:
  8537. Offset    Size    Description    (Table 03707)
  8538.  00h 12 BYTEs    reserved
  8539.  0Ch    WORD    1A00h (verb "CONVERT")
  8540.  0Eh  6 BYTEs    00h
  8541.  14h    DWORD    (big-endian) return code
  8542.  18h    BYTE    conversion
  8543.         00h ASCII to EBCDIC
  8544.         01h EBCDIC to ASCII
  8545.  19h    BYTE    character set
  8546.         00h AE
  8547.         01h A
  8548.         02h G
  8549.  1Ah    WORD    length of string to convert
  8550.  1Ch    DWORD    pointer to source
  8551.  20h    DWORD    pointer to target
  8552. --------N-68FC-------------------------------
  8553. INT 68 - APPC/PC - ENABLE/DISABLE MESSAGE TRACING
  8554.     AH = FCh
  8555.     AL = new state
  8556.         00h disable tracing
  8557.         01h enable tracing
  8558.         DX = number of bytes to keep (0=all)
  8559. SeeAlso: AH=FDh,AH=FEh
  8560. --------N-68FD-------------------------------
  8561. INT 68 - APPC/PC - ENABLE/DISABLE API VERB TRACING
  8562.     AH = FDh
  8563.     AL = new tracing state (00h disabled, 01h enabled)
  8564. SeeAlso: AH=FAh,AH=FCh,AH=FEh
  8565. --------N-68FE-------------------------------
  8566. INT 68 - APPC/PC - SET TRACE DESTINATION
  8567.     AH = FEh
  8568.     AL = trace destinations (see #03708)
  8569.     DS:DX -> trace stats record if AL bit 0 set (see #03709)
  8570. SeeAlso: AH=FCh,AH=FDh
  8571.  
  8572. Bitfields for trace destinations:
  8573. Bit(s)    Description    (Table 03708)
  8574.  0    storage (DS:DX -> trace stats record)
  8575.  1    display
  8576.  2    file (trace written to file OUTPUT.PC)
  8577.  3    printer
  8578.  
  8579. Format of APPC/PC Trace Statistics Record:
  8580. Offset    Size    Description    (Table 03709)
  8581.  00h    DWORD    pointer to storage trace buffer
  8582.  04h    WORD    max number of 80-byte records in trace
  8583.  06h    WORD    (high-order byte first!) current record number (must init to 0)
  8584.  08h    DWORD    (high-order byte first!) number of records written (init to 0)
  8585.  0Ch    DWORD    reserved
  8586. Note:    do not move record while trace is active
  8587. --------N-68FF-------------------------------
  8588. INT 68 - APPC/PC - SET PASSTHROUGH
  8589.     AH = FFh
  8590.     DS:DX -> passthrough exit routine
  8591. SeeAlso: AH=07h,INT 68"Novell"
  8592. --------b-69---------------------------------
  8593. INT 69 - Zenith AT BIOS - ???
  8594. Note:    called by INT 09 handler
  8595. --------h-69---------------------------------
  8596. INT 69 C - HP Vectra AT - IRQ17 - KEYBOARD OUTPUT-BUFFER-FULL SERVICE ROUTINE
  8597. SeeAlso: INT 09"IRQ1",INT 68"HP Vectra",INT 6A"HP Vectra"
  8598. --------N-690100-----------------------------
  8599. INT 69 - DECnet DOS CTERM - INSTALLATION CHECK
  8600.     AX = 0100h
  8601. Return: AL = FFh if present
  8602. SeeAlso: AX=010Fh
  8603. --------N-690101-----------------------------
  8604. INT 69 - DECnet DOS CTERM - SEND BYTE
  8605.     AX = 0101h
  8606.     BL = character
  8607.     DX = session handle
  8608. Return: AH >= 80h on error
  8609. SeeAlso: AX=0102h
  8610. --------N-690102-----------------------------
  8611. INT 69 - DECnet DOS CTERM - READ BYTE
  8612.     AX = 0102h
  8613.     DX = session handle
  8614. Return: AH >= 80h on error
  8615.     AH < 80h if successful
  8616.         AL = character
  8617. SeeAlso: AX=0101h
  8618. --------N-690103-----------------------------
  8619. INT 69 - DECnet DOS CTERM - STATUS
  8620.     AX = 0103h
  8621.     DX = session handle
  8622. Return: AH status flags (see #03710)
  8623.     AL = reason code if DECnet error (see #03711)
  8624. SeeAlso: AX=0104h
  8625.  
  8626. Bitfields for DECnet DOS CTERM status flags:
  8627. Bit(s)    Description    (Table 03710)
  8628.  7    session has been aborted
  8629.  6    DECnet error
  8630.  1    trace data available
  8631.  0    receive data available
  8632.  
  8633. (Table 03711)
  8634. Values for reason code:
  8635.  00h    normal disconnect
  8636.  01h    unknown message from host
  8637.  02h    protocol violation from host
  8638.  03h    could not process the initiate message
  8639.  04h    error receiving message from host
  8640.  05h    error sending message to host
  8641.  06h    error checking for message from host
  8642.  07h    remote system does not support CTERM
  8643.  08h    remote system does not support correct protocol version
  8644.  09h    did not receive BIND message from host
  8645.  0Ah    could not send BIND message to host
  8646.  0Bh    no more sessions available
  8647.  0Ch    session does not exist
  8648.  0Dh    not enough memory to complete operation
  8649.  0Eh    connection has broken
  8650. Index:    error codes;DECnet DOS CTERM|DECnet DOS CTERM;error codes
  8651. --------N-690104-----------------------------
  8652. INT 69 - DECnet DOS CTERM - DECnet STATUS
  8653.     AX = 0104h
  8654.     DX = session handle
  8655. Return: AX = reason code (see #03711)
  8656. Note:    use this call when AX=0103h returns a DECnet error
  8657. SeeAlso: AX=0103h
  8658. --------N-690105-----------------------------
  8659. INT 69 - DECnet DOS CTERM - OPEN SESSION
  8660.     AX = 0105h
  8661.     DS:BX -> ASCIZ node name
  8662.     ES:DX -> buffer for session control block (see #03727 at INT 6A/AH=D0h)
  8663. Return: AX <= 0 on error
  8664.     AX > 0 session handle
  8665. SeeAlso: AX=0103h,AX=0106h,AX=010Ah
  8666. --------N-690106-----------------------------
  8667. INT 69 - DECnet DOS CTERM - CLOSE SESSION
  8668.     AX = 0106h
  8669.     DX = session handle
  8670. Return: AH = status
  8671.         00h good close
  8672.         other error code (see #03711)
  8673. SeeAlso: AX=0103h,AX=0105h
  8674. --------N-69010A-----------------------------
  8675. INT 69 - DECnet DOS CTERM - GET SESSION CONTROL BLOCK SIZE
  8676.     AX = 010Ah
  8677. Return: AX = length of session control block in bytes
  8678. SeeAlso: AX=0105h
  8679. --------N-69010B-----------------------------
  8680. INT 69 - DECnet DOS CTERM - GET DECnet SOCKET
  8681.     AX = 010Bh
  8682.     DX = session handle
  8683. Return: AX > 0    DECnet socket for the session
  8684.     AX = 0    no match for handle
  8685. --------N-69010F-----------------------------
  8686. INT 69 - DECnet DOS CTERM - DEINSTALL CTERM
  8687.     AX = 010Fh
  8688. Return: AH = status
  8689.         00h successful uninstall
  8690.         other error code (see #03711)
  8691. Note:    CTERM must have been the last TSR loaded in order to deinstall it
  8692. SeeAlso: AX=0100h
  8693. Index:    uninstall;DECnet DOS CTERM
  8694. --------N-690A-------------------------------
  8695. INT 69 - DECnet DOS 2.1+ - DATA LINK LAYER
  8696.     AH = 0Ah
  8697.     AL = function number (see #03712)
  8698.     ES:BX -> Datalink Communication Block (see #03714)
  8699. Return: AX = status (see #03713)
  8700. SeeAlso: INT 6D"DECnet"
  8701.  
  8702. (Table 03712)
  8703. Values for DECnet DOS Data Link Layer function:
  8704.  00h    initialize
  8705.  01h    open portal
  8706.  02h    close portal
  8707.  03h    enable multicast address
  8708.  04h    disable multicast address
  8709.  05h    transmit
  8710.  06h    request transmit buffer
  8711.  07h    deallocate transmit buffer
  8712.  08h    read channel status
  8713.  09h    read datalink portal list
  8714.  0Ah    read information about a datalink portal
  8715.  0Bh    read and/or clear counters
  8716.  0Ch    request to boot from a network server
  8717.  0Dh    enable Ethernet channel
  8718.  0Eh    disable Ethernet channel
  8719.  0Fh    start MOP/send a System ID message
  8720.  10h    stop MOP
  8721.  11h    get DECPARM
  8722.  12h    set DECPARM
  8723.  13h    external loopback
  8724.  
  8725. (Table 03713)
  8726. Values for DECnet DOS Data Link Layer status:
  8727.  00h    successful
  8728.  01h    hardware failed to initialize
  8729.  02h    channel state was not off (must be off to execute that command)
  8730.  03h    channel state is off (must be on to execute that command)
  8731.  04h    address not set
  8732.  05h    hardware missing
  8733.  06h    buffer too small
  8734.  07h    no more buffers available
  8735.  08h    no more resources available
  8736.  09h    promiscuous receiver active
  8737.  0Ah    non exclusive
  8738.  0Bh    unrecognized portal
  8739.  0Ch    protocol type in use
  8740.  0Dh    not a valid Multicast address
  8741.  0Eh    outstanding calls
  8742.  0Fh    hardware doesn't support receiving bad frames
  8743.  10h    none outstanding
  8744.  11h    no events
  8745.  12h    broken
  8746.  13h    buffer quota exceeded
  8747.  14h    already initialized
  8748.  15h    loopback failure
  8749. Index:    error codes;DECnet DOS|DECnet DOS;error codes
  8750.  
  8751. Format of Datalink Communication Block:
  8752. Offset    Size    Description    (Table 03714)
  8753.  00h    WORD    portal ID
  8754.  02h  6 BYTEs    source address
  8755.  08h  6 BYTEs    destination address
  8756.  0Eh    DWORD    buffer pointer
  8757.  12h    WORD    buffer length
  8758.  14h    WORD    operation
  8759.  16h    BYTE    pad flag (used on open)
  8760.         00h no pad
  8761.         01h pad
  8762.  17h    BYTE    mode flag (used on open)
  8763.         00h 802.3
  8764.         01h Ethernet
  8765.         02h promiscuous
  8766.  18h    DWORD    line status change function
  8767.  1Ch    DWORD    received data function
  8768.  20h    DWORD    transmitted data function
  8769.  24h    BYTE    maximum outstanding transmits/receives
  8770.  25h  2 BYTEs    protocol type
  8771.  27h    WORD    buffers lost
  8772. --------N-694001-----------------------------
  8773. INT 69 - 10NET v5.0 - SYSSVC.COM - ???
  8774.     AX = 4001h
  8775. Return: CF clear
  8776.     AX = 0000h
  8777.     ES:SI -> ???
  8778. InstallCheck:    test for the signature "SYSV" immediately before the interrupt
  8779.       handler
  8780. Range:    INT 60 to INT 7F, selected by configuration
  8781. SeeAlso: AX=4002h
  8782. Index:    installation check;10NET SYSSVC
  8783. --------N-694002-----------------------------
  8784. INT 69 - 10NET v5.0 - SYSSVC.COM - ???
  8785.     AX = 4002h
  8786.     ???
  8787. Return: ???
  8788. InstallCheck:    test for the signature "SYSV" immediately before the interrupt
  8789.       handler
  8790. Range:    INT 60 to INT 7F, selected by configuration
  8791. --------N-694101-----------------------------
  8792. INT 69 - 10NET v5.0 - SYSSVC.COM - ???
  8793.     AX = 4101h
  8794. Return: CF clear
  8795.     ES:SI -> ???
  8796. Range:    INT 60 to INT 7F, selected by configuration
  8797. SeeAlso: AX=4102h,AX=4103h,AX=4104h
  8798. --------N-694102-----------------------------
  8799. INT 69 - 10NET v5.0 - SYSSVC.COM - ???
  8800.     AX = 4102h
  8801.     ???
  8802. Return: ???
  8803. --------N-694103-----------------------------
  8804. INT 69 - 10NET v5.0 - SYSSVC.COM - ???
  8805.     AX = 4103h
  8806.     ???
  8807. Return: ???
  8808. --------N-694104-----------------------------
  8809. INT 69 - 10NET v5.0 - SYSSVC.COM - ???
  8810.     AX = 4104h
  8811.     ???
  8812. Return: ???
  8813. --------N-6942-------------------------------
  8814. INT 69 - 10NET v5.0 - SYSSVC.COM - ???
  8815.     AH = 42h
  8816.     AL = function (01h-14h)
  8817.     ???
  8818. Return: ???
  8819. Range:    INT 60 to INT 7F, selected by configuration
  8820. --------N-6943-------------------------------
  8821. INT 69 - 10NET v5.0 - SYSSVC.COM - ???
  8822.     AH = 43h
  8823.     AL = function (01h-05h)
  8824.     ???
  8825. Return: ???
  8826. --------N-6944-------------------------------
  8827. INT 69 - 10NET v5.0 - SYSSVC.COM - ???
  8828.     AH = 44h
  8829.     AL = function (01h-03h)
  8830.     ???
  8831. Return: ???
  8832. Range:    INT 60 to INT 7F, selected by configuration
  8833. --------N-6949-------------------------------
  8834. INT 69 - 10NET v5.0 - SYSSVC.COM - BUG
  8835.     AH = 49h
  8836. Note:    due to a fencepost error, this function branches to hyperspace
  8837. SeeAlso: AX=4001h,AH=FFh
  8838. --------G-696996-----------------------------
  8839. INT 69 - ISR.COM v1.00 - SPECIFY INTERRUPT HANDLER
  8840.     AX = 6996h
  8841.     DS:DX -> interrupt handler or 0000h:0000h to disable
  8842. Return: AX = 9669h
  8843. Program: ISR (Interrupt Service Reflector) is a TSR by Rich Bono which permits
  8844.       a program to provide hardware interrupt handlers even while being
  8845.       debugged with a debugger that swaps interrupt vectors during
  8846.       debugging.
  8847. Note:    the interrupt vector which is to be reflected is set at installation
  8848.       time and cannot be changed
  8849. --------N-69FF-------------------------------
  8850. INT 69 - 10NET v5.0 - SYSSVC.COM - SIGNAL SYSTEM ERROR
  8851.     AH = FFh
  8852. Return: never???
  8853. Desc:    displays "System Error" message and register dump, then halts system
  8854. InstallCheck:    test for the signature "SYSV" immediately before the interrupt
  8855.       handler
  8856. Range:    INT 60 to INT 7F, selected by configuration
  8857. SeeAlso: AX=4001h,AH=49h
  8858. --------U-6A---------------------------------
  8859. INT 6A - OPTHELP.COM
  8860. Program: OPTHELP is an optionally-resident help system for SLR Systems's OPTASM
  8861.       assembler
  8862. Range:    INT 60h to INT 7Fh, selected by configuration
  8863. --------N-6A---------------------------------
  8864. INT 6A - DECnet DOS - LOCAL AREA TRANSPORT PROGRAM - INSTALLATION CHECK
  8865. InstallCheck:    test for a signature area immediately preceding the interrupt
  8866.       handler (see #03715)
  8867. SeeAlso: AH=01h/DH=FFh,INT 6B"DECnet",INT 6D"DECnet"
  8868. Index:    installation check;DECnet DOS Local Area Transport
  8869.  
  8870. Format of DECnet DOS signature area:
  8871. Offset    Size    Description    (Table 03715)
  8872.  -5    BYTE    major version number
  8873.  -4    BYTE    minor version number
  8874.  -3   3 BYTEs    signature (ASCII "LAT")
  8875. --------h-6A---------------------------------
  8876. INT 6A C - HP Vectra AT - IRQ18 - RESERVED HARDWARE INTERRUPT
  8877. SeeAlso: INT 0A"IRQ2",INT 69"HP Vectra",INT 6B"HP Vectra"
  8878. --------N-6A0000-----------------------------
  8879. INT 6A U - Super-TCP DOS TSR Kernel v3.57 - INSTALLATION CHECK
  8880.     AX = 0000h
  8881. Return: AX = 4357h ('CW')
  8882. Program: Super-TCP is a TCP/IP protocol stack by Frontier Technologies Corp.
  8883. Note:    an alternate installation check is to test for the ASCIZ signature
  8884.       "FTC Super-TCP" three bytes past the interrupt handler
  8885. SeeAlso: AX=0001h,AX=0002h,AX=000Fh,AX=0010h,INT 21/AH=3Fh"BW-TCP"
  8886. SeeAlso: INT 61"FTP Software",INT 62/AH=00h"ETHDEV"
  8887. --------N-6A0001-----------------------------
  8888. INT 6A U - Super-TCP DOS TSR Kernel v3.57 - ???
  8889.     AX = 0001h
  8890.     BH = function number
  8891.         01h ???
  8892.         DS:SI -> ??? 24-byte record1 (see #03717)
  8893.         ES:DI -> buffer containing ???
  8894.         02h ???
  8895.         DS:SI -> ??? 18-byte record2 (see #03718)
  8896.         ES:DI -> buffer containing ???
  8897.         04h ???
  8898.         BL = subfunction
  8899.             01h
  8900.             DS:SI -> ??? 28-byte record3 (see #03719)
  8901.             ES:DI -> buffer containing ???
  8902.             02h
  8903.             DS:SI -> ??? 28-byte record3 (see #03719)
  8904.             ES:DI -> buffer containing ???
  8905.             03h
  8906.             DS:SI -> ??? 28-byte record3 (see #03719)
  8907.             else Return: AX = 0005h
  8908.         05h ???
  8909.         DS:SI -> ??? 20-byte record4 (see #03720)
  8910.         ES:DI -> buffer containing ???
  8911.         06h ???
  8912.         BL = subfunction
  8913.             01h
  8914.             DS:SI -> ??? 40-byte record5 (see #03721)
  8915.             02h
  8916.             DS:SI -> ??? 20-byte record6 (see #03722)
  8917.             ES:DI -> ???
  8918.             03h
  8919.             DS:SI -> ??? 20-byte record6 (see #03722)
  8920.             04h
  8921.             DS:SI -> ??? 46-byte record7 (see #03723)
  8922.             else Return: AX = 0005h
  8923.         11h ???
  8924.         DS:SI -> ??? 28-byte record8 (see #03724)
  8925.         ES:DI -> ???
  8926. Return: AX = function status (see #03716)
  8927. SeeAlso: AX=0000h
  8928.  
  8929. (Table 03716)
  8930. Values for Super-TCP function status:
  8931.  0000h    successful
  8932.  0005h    unsupported function
  8933.  000Ah    out of memory
  8934.  
  8935. Format of record1:
  8936. Offset    Size    Description    (Table 03717)
  8937.  00h  4 BYTEs    ???
  8938.  04h    WORD    size of ES:DI buffer
  8939.  06h 18 BYTEs    ???
  8940.  
  8941. Format of record2:
  8942. Offset    Size    Description    (Table 03718)
  8943.  00h  4 BYTEs    ???
  8944.  04h    WORD    size of ES:DI buffer
  8945.  06h 12 BYTEs    ???
  8946.  
  8947. Format of record3:
  8948. Offset    Size    Description    (Table 03719)
  8949.  00h  2 BYTEs    ???
  8950.  02h    WORD    ???
  8951.  04h    WORD    size of ES:DI buffer
  8952.  06h    WORD    ???
  8953.  08h    WORD    operation number (for function 0401h)
  8954.  0Ah    DWORD    -> ???
  8955.  0Eh    WORD    (ret) ???
  8956.  10h 12 BYTEs    ???
  8957.  
  8958. Format of record4:
  8959. Offset    Size    Description    (Table 03720)
  8960.  00h  4 BYTEs    ???
  8961.  04h    WORD    size of ES:DI buffer
  8962.  06h 14 BYTEs    ???
  8963.  
  8964. Format of record5:
  8965. Offset    Size    Description    (Table 03721)
  8966.  00h    BYTE    operation??? (00h-07h)
  8967.  01h    BYTE    ???
  8968.  02h    WORD    (ret) ???
  8969.  04h    DWORD    -> ???
  8970.  08h  4 BYTEs    ???
  8971.  0Ch    DWORD    -> ??? or 0000h:0000h
  8972.  10h 16 BYTEs    ???
  8973.  20h    DWORD    ???
  8974.  24h  4 BYTEs    ???
  8975.  
  8976. Format of record6:
  8977. Offset    Size    Description    (Table 03722)
  8978.  00h  4 BYTEs    ???
  8979.  04h    WORD    size of ES:DI buffer
  8980.  06h 14 BYTEs    ???
  8981.  
  8982. Format of record7:
  8983. Offset    Size    Description    (Table 03723)
  8984.  00h    WORD    ???
  8985.  02h    WORD    ???
  8986.  04h    WORD    ???
  8987.  06h 40 BYTEs    ???
  8988.  
  8989. Format of record8:
  8990. Offset    Size    Description    (Table 03724)
  8991.  00h  4 BYTEs    ???
  8992.  04h    WORD    size of ES:DI buffer
  8993.  06h  6 BYTEs    ???
  8994.  0Ch    WORD    (ret) ???
  8995.  0Eh    WORD    operation??? (01h-03h)
  8996.  10h 12 BYTEs    ???
  8997. --------N-6A0002-----------------------------
  8998. INT 6A U - Super-TCP DOS TSR Kernel v3.57 - ???
  8999.     AX = 0002h
  9000.     BX = ??? (zero/nonzero)
  9001.     CX = ??? identifier (see AX=0004h)
  9002.     DS:SI -> 40-byte buffer for ??? or 0000h:0000h
  9003.     ES:DI -> buffer for ??? or 0000h:0000h
  9004. Return: AX = 0000h (successful) ???
  9005.     BL = ???
  9006.     BH = ???
  9007.     CX = ???
  9008.     DX = ???
  9009. --------N-6A0003-----------------------------
  9010. INT 6A U - Super-TCP DOS TSR Kernel v3.57 - GET ??? DATA AREA
  9011.     AX = 0003h
  9012. Return: CX:DX -> data area (see #03725)
  9013.  
  9014. Format of Super-TCP data area:
  9015. Offset    Size    Description    (Table 03725)
  9016.  00h  2 BYTEs    ???
  9017.  02h    DWORD    original INT 6A vector
  9018.  06h  2 BYTEs    ???
  9019.  08h 96 BYTEs    array of 16 6-byte ???
  9020.  68h    WORD    number of elements of above array in use
  9021.  6Ah    WORD    ???
  9022.     ???
  9023. --------N-6A0004-----------------------------
  9024. INT 6A U - Super-TCP DOS TSR Kernel v3.57 - ALLOCATE ???
  9025.     AX = 0004h
  9026.     CX = size in ???
  9027. Return: AX = 0000h (successful)
  9028.     CX = DX = ???
  9029. SeeAlso: AX=0005h,AX=000Fh
  9030. --------N-6A0005-----------------------------
  9031. INT 6A U - Super-TCP DOS TSR Kernel v3.57 - FREE/CLOSE ???
  9032.     AX = 0005h
  9033.     CX = ??? identifier (from AX=0004h)
  9034. Return: AX = status (0000h successful, FFFFh failed)
  9035. SeeAlso: AX=0004h,AX=000Fh
  9036. --------N-6A000F-----------------------------
  9037. INT 6A U - Super-TCP DOS TSR Kernel v3.57 - FREE/CLOSE ALL ???
  9038.     AX = 000Fh
  9039. Return: AX = 0000h (successful)
  9040. SeeAlso: AX=0000h,AX=0004h,AX=0005h
  9041. --------N-6A0010-----------------------------
  9042. INT 6A U - Super-TCP DOS TSR Kernel v3.57 - UNINSTALL
  9043.     AX = 0010h
  9044. Return: AX = status
  9045.         0000h successful
  9046.         0002h can't uninstall, interrupt vector hooked by another program
  9047. Program: Super-TCP is a TCP/IP protocol stack by Frontier Technologies Corp.
  9048. Note:    if AX is not one of the values listed here on entry, Super-TCP
  9049.       returns AX=FFFEh
  9050. SeeAlso: AX=0000h
  9051. --------N-6A01--DHFF-------------------------
  9052. INT 6A - DECnet DOS LOCAL AREA TRANSPORT - SEND BYTE
  9053.     AH = 01h
  9054.     DH = FFh
  9055.     AL = character
  9056.     DL = handle
  9057. Return: AH >= 80h on error
  9058. SeeAlso: AH=02h
  9059. --------N-6A02--DHFF-------------------------
  9060. INT 6A - DECnet DOS LOCAL AREA TRANSPORT - READ BYTE
  9061.     AH = 02h
  9062.     DH = FFh
  9063.     DL = handle
  9064. Return: AH < 80h if successful
  9065.         AL = character
  9066.     AH >= 80h on error
  9067. SeeAlso: AH=01h
  9068. --------N-6A03--DHFF-------------------------
  9069. INT 6A - DECnet DOS LOCAL AREA TRANSPORT - STATUS
  9070.     AH = 03h
  9071.     DH = FFh
  9072.     DL = handle
  9073. Return: AH = status flags (see #03726)
  9074.  
  9075. Bitfields for DECnet DOS LAT status flags:
  9076. Bit(s)    Description    (Table 03726)
  9077.  5    transmit buffer empty
  9078.  3    session in start state
  9079.  2    session not active
  9080.  1    unable to queue transmit data
  9081.  0    receive data available
  9082. --------N-6AD0--DHFF-------------------------
  9083. INT 6A - DECnet DOS LOCAL AREA TRANSPORT - OPEN SESSION
  9084.     AH = D0h
  9085.     DH = FFh
  9086.     AL = password flag
  9087.         FFh no password
  9088.         0Fh password at ES:DI
  9089.     ES:BX -> LAT session control block (see #03727)
  9090.     ES:DI -> 16-byte blank-padded password (optional)
  9091. Return: AH = 00h success
  9092.         DL = handle
  9093. SeeAlso: AX=D000h
  9094.  
  9095. Format of LAT Session Control Block:
  9096. Offset    Size    Description    (Table 03727)
  9097.  00h 18 BYTEs    service name
  9098.  12h 18 BYTEs    node name (future use)
  9099.  24h 18 BYTEs    port name (future use)
  9100.  36h    DWORD    -> session stopped post routine
  9101.  3Ah    DWORD    -> service table overflow post routine
  9102.  3Eh    DWORD    -> transmit post routine
  9103.  42h    DWORD    -> receive post routine
  9104.  46h    WORD    session status
  9105.         04h circuit failure
  9106.         08h stop slot received
  9107. ---LAT v???---
  9108.  48h    WORD    slot state (LAT driver use)
  9109.  4Ah    WORD    local credits (LAT driver use)
  9110.  4Ch    DWORD    -> VCB (LAT driver use)
  9111.  50h    WORD    backward slot (LAT driver use)
  9112.  52h    WORD    forward slot (LAT driver use)
  9113.  54h    WORD    remote slot ID (LAT driver use)
  9114.  56h    WORD    local slot ID (LAT driver use)
  9115.  58h    WORD    slot byte count (LAT driver use)
  9116.  5Ah    BYTE    remote credits (LAT driver use)
  9117.  5Bh 255 BYTEs    transmitted data slot
  9118. 15Ah    BYTE    number of receive data slots (4 recommended)
  9119. 15Bh    BYTE    number of occupied slots
  9120. 15Ch    BYTE    index of next receive slot to use
  9121. 15Dh    BYTE    index of current receive slot
  9122. 15Eh    WORD    pointer to first received character
  9123. 160h  N WORDs    pointers to receive slots (buffers); each is 259 bytes
  9124.      259N BYTEs    buffers
  9125. Note:    set post routines to 0000h:0000h if polled operation will be used
  9126. ---LAT v4.1.17---
  9127.  48h    WORD    session state (LAT driver use)
  9128.  4Ah    BYTE    local credits (LAT driver use)
  9129.  4Bh    DWORD    -> VCB (LAT driver use)
  9130.  4Fh    WORD    backward slot (LAT driver use)
  9131.  51h    WORD    forward slot (LAT driver use)
  9132.  53h    BYTE    remote slot ID (LAT driver use)
  9133.  54h    BYTE    local slot ID (LAT driver use)
  9134.  55h    BYTE    slot byte count (LAT driver use)
  9135.  56h    BYTE    remote credits (LAT driver use)
  9136.  57h 255 BYTEs    transmitted data slot
  9137. 156h    BYTE    number of receive data slots (4 recommended)
  9138. 157h    BYTE    number of occupied slots
  9139. 158h    BYTE    index of next receive slot to use
  9140. 159h    BYTE    index of current receive slot
  9141. 15Ah    WORD    pointer to first received character
  9142. 15Ch  N WORDs    pointers to receive slots (buffers); each is 259 bytes
  9143.      259N BYTEs    buffers
  9144. Note:    set post routines to 0000h:0000h if polled operation will be used
  9145. --------N-6AD000DHFF-------------------------
  9146. INT 6A - DECnet DOS LOCAL AREA TRANSPORT - CLOSE SESSION
  9147.     AX = D000h
  9148.     DH = FFh
  9149.     DL = handle
  9150. Return: AX = status (see #03728)
  9151. SeeAlso: AH=D0h
  9152.  
  9153. (Table 03728)
  9154. Values for DECnet DOS LAT function status:
  9155.  0000h    successful
  9156.  0001h    no such session
  9157.  0002h    session not running, try again later
  9158. --------N-6AD100DHFF-------------------------
  9159. INT 6A - DECnet DOS LOCAL AREA TRANSPORT - SEND BREAK
  9160.     AX = D100h
  9161.     DH = FFh
  9162.     DL = handle
  9163. Return: AX = 0000h if successful
  9164.     AH bit 7 set if unable to send break
  9165. --------N-6AD300DHFF-------------------------
  9166. INT 6A - DECnet DOS LOCAL AREA TRANSPORT - RESET LAT COUNTERS
  9167.     AX = D300h
  9168.     DH = FFh
  9169. SeeAlso: AX=D400h
  9170. --------N-6AD400DHFF-------------------------
  9171. INT 6A - DECnet DOS LOCAL AREA TRANSPORT - COPY LAT COUNTERS
  9172.     AX = D400h
  9173.     DH = FFh
  9174.     CX = buffer size
  9175.     ES:BX -> buffer for LAT counters
  9176. Return: AX = status
  9177.         0000h counters copied into buffer
  9178.         FFFFh buffer too small
  9179. SeeAlso: AX=D300h
  9180. --------N-6AD500DHFF-------------------------
  9181. INT 6A - DECnet DOS LOCAL AREA TRANSPORT - GET NEXT LAT SERVICE NAME
  9182.     AX = D500h
  9183.     DH = FFh
  9184.     ES:BX -> 17-byte buffer for name
  9185. Return: AH = 00h if successful
  9186.        ES:BX buffer filled
  9187.     AX = FFFFh if end of table or no name available
  9188. Notes:    use this function to get the names of the hosts on the network
  9189.     successive calls are necessary to get all names
  9190. SeeAlso: AX=D600h/DH=FFh
  9191. --------N-6AD600DHFF-------------------------
  9192. INT 6A - DECnet DOS LOCAL AREA TRANSPORT - LAT SERVICE TABLE RESET
  9193.     AX = D600h
  9194.     DH = FFh
  9195. Return: AX = number of service table entries
  9196.     BX = status
  9197.         0000h service table has not overflowed
  9198.         FFFFh service table has overflowed
  9199. SeeAlso: AX=D500h
  9200. --------!---Section--------------------------
  9201.